36.10. 处理嵌入式 SQL 程序

现在你已经对如何构造嵌入式 SQL C 程序有所了解了,你可能希望知道如何编译它们。在编译之前,你需要让该文件通过嵌入式SQL C预处理器,它会把你用到的SQL转换成特殊的函数调用。在编译之后,你必须链接一个包含所需函数的特殊库。这些函数从参数中取得信息、使用libpq执行SQL命令并且把结果放在指定的参数中用来输出。

该预处理器程序被称作ecpg并且被包括在一个正常的PostgreSQL安装中。嵌入式 SQL 程序通常带有扩展名.pgc。如果你有一个程序文件prog1.pgc,你可以调用下面的命令对它进行预处理:

ecpg prog1.pgc

这将创建一个文件prog1.c。如果你的输入文件不遵循建议的命名模式,你可以用-o选项显式地指定输出文件。

预处理过的文件可以被正常地编译,例如:

cc -c prog1.c

产生的 C 源文件从PostgreSQL安装中包括头文件,因此如果你把PostgreSQL安装在一个不被默认搜索的位置,你必须在编译命令行中增加一个选项(例如-I/usr/local/pgsql/include)。

要链接一个嵌入式 SQL 程序,你需要包括libecpg库,像这样:

cc -o myprog prog1.o prog2.o ... -lecpg

再次,你可能不得不在命令行中增加类似-L/usr/local/pgsql/lib的选项。

你可以使用pg_config 或者pkg-config 加上包名libecpg来得到你的安装路径。

如果你使用make来管理一个大工程的构建过程,把下面的隐式规则包括在你的 makefile 中将会很方便:

ECPG = ecpg

%.c: %.pgc
        $(ECPG) $<

ecpg命令的完整语法可见ecpg

ecpg库默认是线程安全的。不过,你可能需要使用一些线程命令行选项来编译你的客户端代码。