1.首先,编译libpq

下载源码,进入src目录,interface/libpq/win32.mak 文件中,mt命令那些行删掉。

执行 nmake /f win32.mak

在interface/libpq/Release中可以看到libpq.lib

2.服务端配置

修改postgresql.conf

listen_addresses = '*'  # 允许所有连接
logging_collector = on # 打开日志
 
修改pg_hba.conf,添加信任。
 
3.编写代码
 
 // ptest.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
// #include "pch.h"
#include <iostream>
#include <libpq-fe.h> #pragma comment(lib, "libpq.lib")
#pragma comment(lib, "ws2_32.lib")
#pragma comment(lib, "Secur32.lib") int main()
{
const char *conninfo = "postgresql://[email protected]:5432/testdb"; PGconn *conn;
PGresult *res; conn = PQconnectdb(conninfo); if (PQstatus(conn) != CONNECTION_OK)
{
std::cerr << "Connection to db failed:" << PQerrorMessage(conn);
PQfinish(conn);
exit();
} std::cout << "Connect successful!" << std::endl; res = PQexec(conn, "SELECT * FROM pg_tables;"); if (PQresultStatus(res) != PGRES_TUPLES_OK)
{
std::cerr << "EXECUTION failed:" << PQerrorMessage(conn);
PQclear(res);
PQfinish(conn);
exit();
} int nFields;
nFields = PQnfields(res);
//打印属性名字
for (int i = ; i < nFields; ++i)
{
std::cout << PQfname(res, i) << std::ends;
}
std::cout << "\n---" << std::endl; //打印行
for (int i = ; i < PQntuples(res); ++i)
{
for (int j = ; j < nFields; ++j)
{
std::cout << PQgetvalue(res, i, j) <<'\t'<< std::ends;
}
std::cout << std::endl;
} PQclear(res); PQfinish(conn); getchar(); return ;
}
05-11 14:39