任意编程语言访问PostgreSQL:C++接口

任意编程语言访问PostgreSQL:C++接口,第1张

概述今天将介绍如何使用C++访问PostgreSQL。   官方PostgreSQL客户端的C++接口API称为libpqxx,但没有与PostgreSQL源码进行绑定,用户可以从产品分发库或单独下载进行安装。README文件提到用户可以在Linux、BSD、Solaris、Irix、HP-UX、AIX和安装Cygwin的Windows上使用libpqxx。安装libpqxx前要先安装libpq,因为 @H_502_0@今天将介绍如何使用C++访问Postgresql。

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

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

@H_502_0@#include <iostream>
#include <pqxx/pqxx>

@H_502_0@using namespace std;

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

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

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

@H_502_0@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的行显示警告。

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

@H_502_0@  连接,查询与事务处理

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

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

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

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

@H_502_0@  下面看如何使用transactor:

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

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

@H_502_0@ }

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

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

总结

以上是内存溢出为你收集整理的任意编程语言访问PostgreSQL:C++接口全部内容,希望文章能够帮你解决任意编程语言访问PostgreSQL:C++接口所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1179113.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存