PostgreSQL
35.11. Library Functions
The libecpg
library primarily contains “[.quote]#hidden”# functions that are used to implement the functionality expressed by the embedded SQL commands. But there are some functions that can usefully be called directly. Note that this makes your code unportable.
-
ECPGdebug(int +`_`+on`
, FILE *stream
)` turns on debug logging if called with the first argument non-zero. Debug logging is done on _`stream`. The log contains all SQL statements with all the input variables inserted, and the results from the PostgreSQL server. This can be very useful when searching for errors in your SQL statements.
==== Note
On Windows, if the ecpg libraries and an application are compiled with different flags, this function call will crash the application because the internal representation of the
FILE
pointers differ. Specifically, multithreaded/single-threaded, release/debug, and static/dynamic flags should be the same for the library and all applications using that library. -
ECPGget_PGconn(const char *`
connection_name)` returns the library database connection handle identified by the given name. If `connection_name
is set to `NULL, the current connection handle is returned. If no connection handle can be identified, the function returns
NULL
. The returned connection handle can be used to call any other functions from libpq, if necessary.==== Note
It is a bad idea to manipulate database connection handles made from ecpg directly with libpq routines.
-
ECPGtransactionStatus(const char *`
connection_name)` returns the current transaction status of the given connection identified by `connection_name
. See Section 33.2 and libpq’s `PQtransactionStatus() for details about the returned status codes.
-
ECPGstatus(int +`_`+lineno`
, const char* +`_`+connection_name)` returns true if you are connected to a database and false if not. `connection_name
can be `NULL if a single connection is being used.
Prev | Up | Next |
---|---|---|
35.10. Processing Embedded SQL Programs |
35.12. Large Objects |
Submit correction
If you see anything in the documentation that is not correct, does not match your experience with the particular feature or requires further clarification, please use this form to report a documentation issue.
Copyright © 1996-2023 The PostgreSQL Global Development Group