C++ pqxx 工作事务崩溃
C++ pqxx work transaction crashing
我正在使用 c++ PostgreSQL libpqxx 库,我不确定为什么我无法打开 transaction/nontransaction 对象。
我目前的代码如下
#include <iostream>
#include <pqxx/pqxx>
using namespace std;
using namespace pqxx;
int main() {
// define variables
string params;
connection* pgsql;
string sql;
// db connection parameters
params = "dbname=dummy user=postgres password=postgres hostaddr=10.10.0.2 port=5431";
try {
// make connection
pgsql = new connection(params);
} catch(const exception &log) {
// connection failed
cerr << log.what() << endl;
}
// prepare sql
sql = " select * from categories where cat_idno = ";
pgsql->prepare("categories", sql)("integer");
// execute transaction
// this bit doesn't work
work tr(pgsql);
result row = tr.prepared("categories")(1).exec();
tr.commit();
// disconnect
pgsql->disconnect();
}
它与数据库的连接正常,我的 sql 准备也正常,但编译失败(顺便说一句,我在 CentOS 5 上编译)
g++ -o ./pgsqltest ./pgsqltest02.cpp -lpqxx
给我以下错误
./pgsqltest02.cpp: In function ‘int main()’:
./pgsqltest02.cpp:24: error: no matching function for call to ‘pqxx::transaction<read_committed, read_write>::transaction(pqxx::connection*&)’
/usr/include/pqxx/transaction.hxx:102: note: candidates are: pqxx::transaction<ISOLATIONLEVEL, READWRITE>::transaction(pqxx::connection_base&) [with pqxx::isolation_level ISOLATIONLEVEL = read_committed, pqxx::readwrite_policy READWRITE = read_write]
/usr/include/pqxx/transaction.hxx:97: note: pqxx::transaction<ISOLATIONLEVEL, READWRITE>::transaction(pqxx::connection_base&, const std::string&) [with pqxx::isolation_level ISOLATIONLEVEL = read_committed, pqxx::readwrite_policy READWRITE = read_write]
/usr/include/pqxx/transaction.hxx:87: note: pqxx::transaction<read_committed, read_write>::transaction(const pqxx::transaction<read_committed, read_write>&)
我不确定为什么会这样,也许我遗漏了一些非常明显的东西
错误与编译命令有关,它需要指向 libpqxx headers 和二进制文件的额外参数。正确的编译命令是
g++ -o ./pgsqltest ./pgsqltest02.cpp -I /opt/libpqxx/include -L /opt/libpqxx/lib -lpq -lpqxx
我正在使用 c++ PostgreSQL libpqxx 库,我不确定为什么我无法打开 transaction/nontransaction 对象。
我目前的代码如下
#include <iostream>
#include <pqxx/pqxx>
using namespace std;
using namespace pqxx;
int main() {
// define variables
string params;
connection* pgsql;
string sql;
// db connection parameters
params = "dbname=dummy user=postgres password=postgres hostaddr=10.10.0.2 port=5431";
try {
// make connection
pgsql = new connection(params);
} catch(const exception &log) {
// connection failed
cerr << log.what() << endl;
}
// prepare sql
sql = " select * from categories where cat_idno = ";
pgsql->prepare("categories", sql)("integer");
// execute transaction
// this bit doesn't work
work tr(pgsql);
result row = tr.prepared("categories")(1).exec();
tr.commit();
// disconnect
pgsql->disconnect();
}
它与数据库的连接正常,我的 sql 准备也正常,但编译失败(顺便说一句,我在 CentOS 5 上编译)
g++ -o ./pgsqltest ./pgsqltest02.cpp -lpqxx
给我以下错误
./pgsqltest02.cpp: In function ‘int main()’:
./pgsqltest02.cpp:24: error: no matching function for call to ‘pqxx::transaction<read_committed, read_write>::transaction(pqxx::connection*&)’
/usr/include/pqxx/transaction.hxx:102: note: candidates are: pqxx::transaction<ISOLATIONLEVEL, READWRITE>::transaction(pqxx::connection_base&) [with pqxx::isolation_level ISOLATIONLEVEL = read_committed, pqxx::readwrite_policy READWRITE = read_write]
/usr/include/pqxx/transaction.hxx:97: note: pqxx::transaction<ISOLATIONLEVEL, READWRITE>::transaction(pqxx::connection_base&, const std::string&) [with pqxx::isolation_level ISOLATIONLEVEL = read_committed, pqxx::readwrite_policy READWRITE = read_write]
/usr/include/pqxx/transaction.hxx:87: note: pqxx::transaction<read_committed, read_write>::transaction(const pqxx::transaction<read_committed, read_write>&)
我不确定为什么会这样,也许我遗漏了一些非常明显的东西
错误与编译命令有关,它需要指向 libpqxx headers 和二进制文件的额外参数。正确的编译命令是
g++ -o ./pgsqltest ./pgsqltest02.cpp -I /opt/libpqxx/include -L /opt/libpqxx/lib -lpq -lpqxx