返回介绍

I. 教程

II. SQL 语言

III. 服务器管理

IV. 客户端接口

V. 服务器端编程

VI. 参考手册

VII. 内部

VIII. 附录

28.15. 制作 libpq 程序

发布于 2019-09-30 03:08:14 字数 2340 浏览 881 评论 0 收藏 0

要制作(也就是说编译和链接)你的 libpq 程序,你需要做下面的一些事情:

  • 包含 libpq-fe.h 头文件∶

    #include <libpq-fe.h>

    如果你没干这件事,那么你通常会看到类似下面这样的来自编译器的信息∶

    foo.c: In function `main':foo.c:34: `PGconn' undeclared (first use in this function)foo.c:35: `PGresult' undeclared (first use in this function)foo.c:54: `CONNECTION_BAD' undeclared (first use in this function)foo.c:68: `PGRES_COMMAND_OK' undeclared (first use in this function)foo.c:95: `PGRES_TUPLES_OK' undeclared (first use in this function)

  • 告诉你的编译器PostgreSQL头文件的安装位置,方法是给你的编译器提供-Idirectory 选项。(有些时候编译器会查找缺省的目录,因此你可以忽略这些选项。)比如,你的命令行看起来象∶

    cc -c -I/usr/local/pgsql/include testprog.c

    如果你在使用制作文件(makefile),那么向 CPPFLAGS变量中增加下面的选项∶

    CPPFLAGS += -I/usr/local/pgsql/include

    如果你的程序可能会被别人编译,那么你应该避免象上面那样把目录路径写成硬编码。取而代之的是你可以运行 pg_config 工具找出头文件在系统的什么地方∶

    $ pg_config --includedir/usr/local/include

    如果没能给编译器提供正确的选项将产生类似下面这样的错误信息

    testlibpq.c:8:22: libpq-fe.h: No such file or directory

  • 在链接最后的程序的时候,声明选项 -lpq,这样就可以把 libpq 库链接进来,还要声明 -Ldirectory以告诉编译器 libpq 所处的目录。(同样,编译器也会搜索一些缺省的目录。)为了尽可能提高可移植性,你应该把 -L 选项放在-lpq 选项前面。比如∶

    cc -o testprog testprog1.o testprog2.o -L/usr/local/pgsql/lib -lpq

    你也可以用 pg_config 找出库目录∶

    $ pg_config --libdir/usr/local/pgsql/lib

    指向这类问题的错误信息会是类似下面这个样子。

    testlibpq.o: In function `main':testlibpq.o(.text+0x60): undefined reference to `PQsetdbLogin'testlibpq.o(.text+0x71): undefined reference to `PQstatus'testlibpq.o(.text+0xa4): undefined reference to `PQerrorMessage'

    这意味着你忘记 -lpq 了。

    /usr/bin/ld: cannot find -lpq

    这意味着你忘记这-L 或者没有声明正确的目录。

如果你的代码引用了头文件 libpq-int.h,而且你不原意修补你的代码以避免使用它,那么从PostgreSQL7.2 开始,该文件将在 includedir/postgresql/internal/libpq-int.h 里出现,因此你需要给你的编译器命令行增加合适的 -I 选项。

<
PrevHomeNext
在多线程程序里的行为Up例子程序

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文