今天将介绍如何使用C++访问PostgreSQL。

  官方PostgreSQL客户端的C++接口API称为libpqxx,但没有与PostgreSQL源码进行绑定,用户可以从产品分发库或单独下载进行安装。README文件提到用户可以在Linux、BSD、Solaris、Irix、HP-UX、AIX和安装Cygwin的Windows上使用libpqxx。安装libpqxx前要先安装libpq,因为前者是基于后者的。

  在C++中,namespace被命名为pqxx,用户必须包含以该名称命名的头文件。以下为一个简单连接与查询的例子:

#include <iostream>
#include <pqxx/pqxx>

using namespace std;

int main()
{
    pqxx::connection conn;
    pqxx::work w(conn);
    pqxx::result res = w.exec("SELECT 1");
    w.commit();

cout << res[0][0].as<int>() << endl;
}
  如果运行正确,则该程序会打印出“1”,可以使用try/catch关键字来处理连接中可能出现的错误。如果要像在C语言中那样使用argv[x],可以像如下方法连接字符串:

pqxx::result res = w.exec("SELECT" + w.quote(argv[1]));
  那么,该如何对数据进行查询与返回呢?由于保存数据的res变量是一个数组,因此可以利用循环来读取res中的数据元素:

for (int rownr=0; rownr < res.size(); ++rownr)
{
    const result::tuple row = res[rownr];
    for (int colnr=0; colnr < row.size(); ++colnr)
    {
        const result::field = row[colnr];
        cout << field.c_str() << \t;
    }
    cout << endl;
}
  要记得在写代码的时候加上using namespace std;,如果不加的话在编译时会在使用cout与endl的行显示警告。

  libpqxx在字符串转换方面提供大量函数,最有意思的函数为from_string与to_string,第一个函数只有一个字符串参数和一个 T& obj参数,T表示已存在的内置类型,第二个函数只有一个T& obj变量,函数将其转换为字符串。更多详细内容可以阅读相关文档。

  连接,查询与事务处理

  本节的其余部分代码,读者最好使用using namespace pqxx;,因为可以在写代码时免去写一些数据类型,省去一些不必要的麻烦,如可以不必写pqxx::...。现在连接一个数据库,执行一次事务处理,之后进行一次查询,读者会看到代码与前文的C代码不太一样。

  可以使用只包含一个参数的结构,如定义了连接选项(数据库名、用户名等)的字符串。由于默认用户名为postgres,因此本例代码没有包含用户名:

connection Conn("dbname=testdb1 hostaddr=192.168.0.101");
  现在已经打开了一个连接,执行没有出错。不过到目前为止还不能进行查询,还需要使用transactor来打开一个事务处理,这样可以在连接突然断开时省去一些麻烦与时间。transactor是一个functor,如果在创建连接时需要知道连接的状态,则该运算符非常有效,而不能仅仅使用简单的函数或函数指针。

  functor是一个函数对象,可以将其看成一个状态查询函数。例如在C++中操作符“()”可以被重载,因此可以将任意数量的数据元素放到括号中。也许有读者会认为functor是定义操作符()的类,如果想要设计一个函数使两个给定的作为参数的值相加,则必须要对这些值进行硬编码。functor考虑到硬编码的限制,允许用户使用一个结构体,并将一个新对象“覆盖”要相加的第一个值,给开发者更多的灵活性。

  下面看如何使用transactor:

  // 假设已经打开一个连接

class Transaction : public transactor<>
{
public:
     void operator () (transaction<> & t)
     {
         t.exec ("INSERT INTO mytable VALUES(val1,val2)");

}

void on_abort (const string & msg)
     {
         cout << "Transaction failed with message: " << msg << endl;
     }
};
  //在 main()函数中

conn.perform (Transaction());
  通过本节内容可以看到,用C++代码对数据库进行查询并不难,用户可以通过定义事务处理(transactions)并适当规范化查询结果(参考stringstream),其余部分可以使用循环来实现。

转载于:https://blog.51cto.com/wws5201985/804114

任意编程语言访问PostgreSQL:C++接口相关推荐

  1. postgresql c语言,任意语言访问PostgreSQL:C语言接口

    开源软件的一个好处是可以根据需要修改程序代码.如果程序后台使用PostgreSQL数据库,可以很容易用各种语言对其进行访问.本文作为系列文章的第一篇,会陆续介绍C.C++.PHP.Tcl.Python ...

  2. python postgresql跨数据库查询_python访问PostgreSQL数据库之连接库Psycopg2

    python访问PostgreSQL数据库之连接库Psycopg2 作者:佣工7001 由于要在python访问PostgreSQL数据库,需要一个符合DB-API的连接库.通过搜索,锁定两个候选库: ...

  3. windows下c 用mysql数据库_Windows环境下C/C++访问PostgreSQL数据库

    PostgreSQL是一款在Linux环境下应用十分广泛的轻量级关系型数据库,大家都听说过MySQL,却对PostgreSQL鲜有耳闻,它其实在性能.应用领域上和MySQL不相上下.网上关于Windo ...

  4. 外网访问postgresql设置

    安装PostgreSQL数据库之后,默认只能本地访问连接.如果想在其他主机上访问PostgreSQL数据库服务器,就需要进行相应的配置. 1.修改postgresql.conf文件 在安装目录下dat ...

  5. Oracle配置dblink访问PostgreSQL

    Oracle dblink的底层是通过ODBC连接PostgreSQL执行SQL的,需安装unixODBC和PostgreSQL ODBC驱动(它们的配置文件是:odbcinst.ini和odbc.i ...

  6. Serverless 解惑——函数计算如何访问 PostgreSQL 数据库

    函数计算(Function Compute):函数计算 是事件驱动的全托管计算服务.使用函数计算,您无需采购与管理服务器等基础设施,只需编写并上传代码.函数计算为您准备好计算资源,弹性地可靠地运行任务 ...

  7. 使用.Net访问Office编程接口

    在这篇文章里面,我将向大家介绍如何在.Net中访问Office所公开的编程接口.其实,不管是使用哪种具体的技术来针对Office进行开发(比如VSTO,或者用C#编写一个Office Add-in,或 ...

  8. Wget CVE-2014-4877:FTP 符号链接任意文件系统访问

    Wget 爆出 CVE-2014-4877 漏洞:FTP 符号链接任意文件系统访问. Package: wget Version: 1.15-1 Severity: important Upstrea ...

  9. C#访问postgresql数据库类MyPostDB的实现

    为了访问PostgreSQL数据库,需要从pgfoundry网站,下载Npgsql .Net Data Provider for Postgresql的组件. 访问 URL:http://pgfoun ...

最新文章

  1. ffmpeg文件拼接
  2. Flink从入门到精通100篇(十九)-基于 Flink 的大规模准实时数据分析平台的建设实践
  3. SAP Kyma上mqtt前缀的endpoint
  4. Iphone表视图的简单操作
  5. java fly bird小游戏_java swing实现的小游戏flybird源码附带视频配置修改教程
  6. 《Python语言程序设计》——3.4 实例研究:最小数量的硬币
  7. 查看 chrome 浏览器中的 Headers
  8. mybatis如何处理参数
  9. bzoj1385 [Baltic2000]Division expression
  10. socket.onmessage没有接收到服务器消息_IM服务器设计-如何解决消息的乱序
  11. 简单的Jenkins配置tomcat
  12. C语言(面积计算器)不能输入负数[程序以要求]
  13. Turbo编译码Matlab仿真解读 -- WuYufei_matlab
  14. JAVA学习(五):Java面向对象编程基础
  15. VS2017 Ankhsvn不可用
  16. 网页前端设计一般思路
  17. iOS 中的编码方式详解(主要讲解Unicode)
  18. 如花搞笑图片集锦(转贴)
  19. 小米笔记本降价销售或预示其销售未如理想
  20. 雨听 | 英语学习笔记(十一)~作文范文:公园的免费入口

热门文章

  1. FPGA的发展历史及相关名词解释
  2. HashSet和HashMap的区别
  3. C++中如何使输出的1变成01
  4. 光流 | OpenCV3实现LK Optical Flow(代码类)
  5. 北斗导航 | Matlab实现电离层延迟计算:Klobuchar(源代码)
  6. Unable to compile class for JSP的解决方法
  7. 树莓派实现AD转换(pcf8591模块)
  8. 如何设置窗口立即刷新显示
  9. 用电梯服务器怎样解电梯显示E34,默纳克品牌电梯故障代码e41怎么处理
  10. c++计算-eigen(1)