35.11. 库函数
libecpg
库主要包含用于实现嵌入式 SQL 命令所表达功能的“隐藏”函数。但是也有一些可以被直接调用的函数。但是注意这会让你的代码不可移植。
如果调用时第一个参数非零,
ECPGdebug(int
会打开调试日志。调试日志在on
, FILE *stream
)流
上完成。该日志包含所有插入了输入变量的SQL语句,以及来自于PostgreSQL服务器的结果。在你的SQL语句中查找错误时这会非常有用。注意
在 Windows 上,如果ecpg库和应用使用不同标志编译的,这个函数调用将会是应用崩溃,因为
FILE
指针的内部表达不同。特别地,库和使用库的应用应该使用相同的多线程/单线程、发行/调试以及静态/动态标志。ECPGget_PGconn(const char *
返回由给定名称标识的库数据库连接句柄。如果connection_name
)connection_name
被设置为NULL
,当前连接句柄将被返回。如果无法定位到连接句柄,该函数返回NULL
。如果需要,返回的连接句柄可以被用来调用任何其他来自于libpq的函数。注意
直接使用libpq例程来操纵ecpg中建立的数据库连接句柄是一种糟糕的做法。
ECPGtransactionStatus(const char *
返回由connection_name
)connection_name
标识的给定连接的当前事务状态。 关于返回的状态代码请参考第 33.2 节 和 libpq的PQtransactionStatus
。如果你连接到了一个数据库,
ECPGstatus(int
会返回真;否则返回假。 如果使用的是一个单一连接,lineno
, const char*connection_name
)connection_name
可以为NULL
。