検索
ホームページデータベースmysql チュートリアル循序渐进PostgreSQL: 学习pqxx C++ API访问

习惯了C++来开发的人,可能更倾向于使用c++库来访问PostgreSQL。libpqxx很早以前就推出了。目前已经到了4.0版。本文就简单的介绍

1. 简介

习惯了C++来开发的人,可能更倾向于使用c++库来访问PostgreSQL。libpqxx很早以前就推出了。目前已经到了4.0版。本文就简单的介绍如何使用它,,Linux平台编译相对简单,这里就介绍一下Windows平台下的使用。

libpqxx的下载地址:直接上这里

由于libpqxx对libpq的C-API进行了很好的封装,从而可以节省大量的编码时间。

2. 编译过程

将libpqxx解压到一固定目录。你需要提前编译好或安装好的客户端库,通常为了方便,这里假定你已经有一个PG的安装版或者解压缩版,在c:\pgsql里头。以PG9.x为例。

1. 进入libpqxx源码目录,备份并修改win32\common文件,将PGSQLSRC的值指向正确的地方:

这里是PGSQLSRC="c:\pgsql"

后边还有很多目录位置需要调整,针对我们这种情况,通常都是保留安装版本的设置,如:LIBPQINC=$(PGSQLSRC)\include, 而注释掉#LIBPQINC=$(PGSQLSRC)\interfaces\libpq, 其它几个值都如此类推。

2. 拷贝一些编译相关的头文件

针对具体版本,9.0的,将config\sample-headers\libpq\9.0\pqxx复制到include下边

针对VS2008的,将config\sample-headers\compiler\VisualStudio2008\pqxx复制到include目录下边, 如果是VS2005,以此类推。

3. 编译

program files->VS2008-->Visual studio tools->Visual Studio 2008 Command Prompt, 进入命令行, 在此进入libpqxx的源代码根目录,执行:

nmake /f win32\vc-libpqxx.mak ALL,

得到如下中间过程:

link.exe kernel32.lib ws2_32.lib advapi32.lib /nologo /dll /machine:I386 
 shell32.lib secur32.lib wldap32.lib /libpath:"C:\hisql-x86-2.0.1"\lib libpq.lib 
  "ObjDllRelease\binarystring.obj"  "ObjDllRelease\connection.obj"  "ObjDllRelea 
se\connection_base.obj"  "ObjDllRelease\cursor.obj"  "ObjDllRelease\dbtransactio 
n.obj"  "ObjDllRelease\errorhandler.obj"  "ObjDllRelease\except.obj"  "ObjDllRel 
ease\field.obj"  "ObjDllRelease\largeobject.obj"  "ObjDllRelease\nontransaction. 
obj"  "ObjDllRelease\notification.obj"  "ObjDllRelease\notify-listen.obj"  "ObjD 
llRelease\pipeline.obj"  "ObjDllRelease\prepared_statement.obj"  "ObjDllRelease\ 
result.obj"  "ObjDllRelease\robusttransaction.obj"  "ObjDllRelease\statement_par 
ameters.obj"  "ObjDllRelease\strconv.obj"  "ObjDllRelease\subtransaction.obj"  " 
ObjDllRelease\tablereader.obj"  "ObjDllRelease\tablestream.obj"  "ObjDllRelease\ 
tablewriter.obj"  "ObjDllRelease\transaction.obj"  "ObjDllRelease\transaction_ba 
se.obj"  "ObjDllRelease\tuple.obj"  "ObjDllRelease\util.obj"  "ObjDllRelease\lib 
pqxx.obj" /out:"lib\libpqxx.dll" /implib:"lib\libpqxx.lib" 
  Creating library lib\libpqxx.lib and object lib\libpqxx.exp 

[plain] view plaincopyprint?

link.exe kernel32.lib ws2_32.lib advapi32.lib /nologo /dll /machine:I386

shell32.lib secur32.lib wldap32.lib /libpath:"C:\hisql-x86-2.0.1"\lib libpq.lib

"ObjDllRelease\binarystring.obj"  "ObjDllRelease\connection.obj"  "ObjDllRelea

se\connection_base.obj"  "ObjDllRelease\cursor.obj"  "ObjDllRelease\dbtransactio

n.obj"  "ObjDllRelease\errorhandler.obj"  "ObjDllRelease\except.obj"  "ObjDllRel

ease\field.obj"  "ObjDllRelease\largeobject.obj"  "ObjDllRelease\nontransaction.

obj"  "ObjDllRelease\notification.obj"  "ObjDllRelease\notify-listen.obj"  "ObjD

llRelease\pipeline.obj"  "ObjDllRelease\prepared_statement.obj"  "ObjDllRelease\

result.obj"  "ObjDllRelease\robusttransaction.obj"  "ObjDllRelease\statement_par

ameters.obj"  "ObjDllRelease\strconv.obj"  "ObjDllRelease\subtransaction.obj"  "

ObjDllRelease\tablereader.obj"  "ObjDllRelease\tablestream.obj"  "ObjDllRelease\

tablewriter.obj"  "ObjDllRelease\transaction.obj"  "ObjDllRelease\transaction_ba

se.obj"  "ObjDllRelease\tuple.obj"  "ObjDllRelease\util.obj"  "ObjDllRelease\lib

pqxx.obj" /out:"lib\libpqxx.dll" /implib:"lib\libpqxx.lib"

Creating library lib\libpqxx.lib and object lib\libpqxx.exp

link.exe kernel32.lib ws2_32.lib advapi32.lib /nologo /dll /machine:I386

shell32.lib secur32.lib wldap32.lib /libpath:"C:\hisql-x86-2.0.1"\lib libpq.lib

"ObjDllRelease\binarystring.obj"  "ObjDllRelease\connection.obj"  "ObjDllRelea

se\connection_base.obj"  "ObjDllRelease\cursor.obj"  "ObjDllRelease\dbtransactio

n.obj"  "ObjDllRelease\errorhandler.obj"  "ObjDllRelease\except.obj"  "ObjDllRel

ease\field.obj"  "ObjDllRelease\largeobject.obj"  "ObjDllRelease\nontransaction.

obj"  "ObjDllRelease\notification.obj"  "ObjDllRelease\notify-listen.obj"  "ObjD

llRelease\pipeline.obj"  "ObjDllRelease\prepared_statement.obj"  "ObjDllRelease\

result.obj"  "ObjDllRelease\robusttransaction.obj"  "ObjDllRelease\statement_par

ameters.obj"  "ObjDllRelease\strconv.obj"  "ObjDllRelease\subtransaction.obj"  "

ObjDllRelease\tablereader.obj"  "ObjDllRelease\tablestream.obj"  "ObjDllRelease\

tablewriter.obj"  "ObjDllRelease\transaction.obj"  "ObjDllRelease\transaction_ba

se.obj"  "ObjDllRelease\tuple.obj"  "ObjDllRelease\util.obj"  "ObjDllRelease\lib

pqxx.obj" /out:"lib\libpqxx.dll" /implib:"lib\libpqxx.lib"

Creating library lib\libpqxx.lib and object lib\libpqxx.exp  最终会在lib目录下生成:

[plain] view plaincopyprint?

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0>dir/b/s lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpq.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpq.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.dll.manifest

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.exp

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.dll.manifest

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.exp

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.ilk

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.pdb

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx_static.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx_staticD.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\msdia80.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0>dir/b/s lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpq.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpq.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.dll.manifest

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.exp

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.dll

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.dll.manifest

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.exp

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.ilk

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxxD.pdb

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx_static.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\libpqxx_staticD.lib

D:\Projects\hisql.svn\trunk\learning\libpqxx-4.0\lib\msdia80.dll

下边来看看最简单的示例:

iihero=# create user foo password 'foo1';

CREATE ROLE

[sql] view plaincopyprint?

iihero=> create table t(id int primary key, col2 varchar(32));

注意:  CREATE TABLE / PRIMARY KEY 将要为表 "t" 创建隐含索引 "t_pkey"

CREATE TABLE

iihero=> \encoding

GBK

iihero=> insert into t values(1 ,'不同类型的列表');

INSERT 0 1

iihero=> select * from t;

id |      col2

----+----------------

1 | 不同类型的列表

(1 行记录)

iihero=> create table t(id int primary key, col2 varchar(32));

注意:  CREATE TABLE / PRIMARY KEY 将要为表 "t" 创建隐含索引 "t_pkey"

CREATE TABLE

iihero=> \encoding

GBK

iihero=> insert into t values(1 ,'不同类型的列表');

INSERT 0 1

iihero=> select * from t;

id |      col2

----+----------------

1 | 不同类型的列表

(1 行记录)

将编译出来后的include, lib目录提取到固定的目录,与你原来的postgresql的include和lib目录,可以合到一起。给开发使用。

下边是一个最简单的示例:

[cpp] view plaincopyprint?

#include <iostream></p>
<p>#include <pqxx/pqxx></p>
<p>int main()</p>
<p>{</p>
<p>pqxx::connection conn("dbname=iihero hostaddr=127.0.0.1 user=foo password=foo1" );</p>
<p>if(conn.is_open())</p>
<p>{</p>
<p>std::cout << "Connection succesful!" << std::endl;</p>
<p>std::cout << conn.options()<<std::endl;</p>
<p>}</p>
<p>else</p>
<p>{</p>
<p>std::cout << "Something went wrong... oops" << std::endl;</p>
<p>}</p>
<p>pqxx::work w(conn);</p>
<p>pqxx::result res = w.exec("SELECT 1");</p>
<p>w.commit();</p>
<p>std::cout << res[0][0].as<int>() << std::endl;</p>
<p>}</p>
<p>

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
MySQLでビューを使用することの限界は何ですか?MySQLでビューを使用することの限界は何ですか?May 14, 2025 am 12:10 AM

mysqlviewshavelimitations:1)supportallsqloperations、制限、dataManipulationswithjoinsorubqueries.2)それらは、特にパフォーマンス、特にパルフェクソルラージャターセット

MySQLデータベースのセキュリティ:ユーザーの追加と特権の付与MySQLデータベースのセキュリティ:ユーザーの追加と特権の付与May 14, 2025 am 12:09 AM

reperusermanmanagementInmysqliscialforenhancingsecurationsinginuring databaseaperation.1)usecreateusertoaddusers、指定connectionsourcewith@'localhost'or@'% '。

MySQLで使用できるトリガーの数にどのような要因がありますか?MySQLで使用できるトリガーの数にどのような要因がありますか?May 14, 2025 am 12:08 AM

mysqldoes notimposeahardlimitontriggers、しかしpracticalfactorsdeTerminetheireffectiveuse:1)serverconufigurationStriggermanagement; 2)complentiggersincreaseSystemload;

mysql:Blobを保管しても安全ですか?mysql:Blobを保管しても安全ですか?May 14, 2025 am 12:07 AM

はい、それはssafetostoreblobdatainmysql、butonsiderheSeCactors:1)Storagespace:blobscanconsumesificantspace.2)パフォーマンス:パフォーマンス:大規模なドゥエットブロブスメイズ階下3)backupandrecized recized recized recize

MySQL:PHP Webインターフェイスを介してユーザーを追加しますMySQL:PHP Webインターフェイスを介してユーザーを追加しますMay 14, 2025 am 12:04 AM

PHP Webインターフェイスを介してMySQLユーザーを追加すると、MySQLI拡張機能を使用できます。手順は次のとおりです。1。MySQLデータベースに接続し、MySQLI拡張機能を使用します。 2。ユーザーを作成し、CreateUserステートメントを使用し、パスワード()関数を使用してパスワードを暗号化します。 3. SQLインジェクションを防ぎ、MySQLI_REAL_ESCAPE_STRING()関数を使用してユーザー入力を処理します。 4.新しいユーザーに権限を割り当て、助成金ステートメントを使用します。

MySQL:BLOBおよびその他のNO-SQLストレージ、違いは何ですか?MySQL:BLOBおよびその他のNO-SQLストレージ、違いは何ですか?May 13, 2025 am 12:14 AM

mysql'sblobissuitable forstoringbinarydatawithinarationaldatabase、whileenosqloptionslikemongodb、redis、andcassandraofferferulesions forunstructureddata.blobissimplerbutcanslowdowdowd withwithdata

MySQLユーザーの追加:構文、オプション、セキュリティのベストプラクティスMySQLユーザーの追加:構文、オプション、セキュリティのベストプラクティスMay 13, 2025 am 12:12 AM

toaddauserinmysql、使用:createuser'username '@' host'identifidedby'password '; here'showtodoitsely:1)chosehostcarefilytoconを選択しますTrolaccess.2)setResourcelimitslikemax_queries_per_hour.3)usestrong、uniquasswords.4)endforcessl/tlsconnectionswith

MySQL:文字列データ型の一般的な間違いを回避する方法MySQL:文字列データ型の一般的な間違いを回避する方法May 13, 2025 am 12:09 AM

toavoidcommonMonmistakeswithStringDatatypesinmysql、undultingStringTypenuste、choosetherightType、andManageEncodingandCollat​​ionsEttingtingive.1)U​​secharforfixed-LengthStrings、Varcharforaible Length、AndText/Blobforlardata.2)setCurrectCherts

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SecLists

SecLists

SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター