首先,你需要在你的代码中包含 libpq 头文件:
#include <libpq-fe.h>
然后,你可以使用以下代码来打开一个连接到 PostgreSQL 数据库的会话:
PGconn *conn = PQconnectdb("host=localhost user=your_username password=your_password dbname=your_db_name");
if (PQstatus(conn) != CONNECTION_OK) { // 如果连接不成功,打印错误信息并退出 fprintf(stderr, "Connection to database failed: %s", PQerrorMessage(conn)); PQfinish(conn); return 1; }
然后,你可以使用以下代码来执行 COPY 命令,将数据从 stdin 导入到数据库中的一张表:
PGresult *res = PQexec(conn, "COPY my_table FROM STDIN WITH CSV");
if (PQresultStatus(res) != PGRES_COPY_IN) { // 如果 COPY 命令执行不成功,打印错误信息并退出 fprintf(stderr, "COPY command failed: %s", PQerrorMessage(conn)); PQclear(res); PQfinish(conn); return 1; }
PQclear(res);
最后&