- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在使用 C
中的 libpq-fe
库来连接到 postgres 数据库。
我正在使用返回时间戳的 libpqfe
从我的代码中调用存储过程。
我想将这个时间戳存储到一个 char 数组中。但要这样做,我首先必须知道时间戳的大小,以便我可以声明数组。为了获得大小,我使用了 int PQfsize(PGresult *res, int field_index);
。您可以找到更多相关信息 here .
它返回值 8
。但实际上时间戳的大小(不带区域)是 19
。
为什么 PQfsize 返回错误值?
我知道时间戳的大小是恒定的,我可以直接声明一个数组,然后使用 PQgetvalue
检索值,但是如何为没有固定大小的字段声明数组。
如何从 PGresult
中检索一个字段并将其存储到任何变量中?
最佳答案
PQfsize 没有返回错误的值。
如果您运行下面的查询,您也会得到答案 8,因为在您的 Postgres 版本中,时间戳在内部存储为一个 8 字节(64 位)整数。
select typlen from pg_type where oid = 'timestamp'::regtype::oid;
根据您链接的文档,PQfsize 返回数据库元组中为该字段分配的空间,换句话说,服务器的数据类型二进制表示的大小。
PQgetlength 返回字段(属性)的字节长度。元组和字段索引从 0 开始。
这是特定数据值的实际数据长度,即 PQgetvalue 指向的对象的大小。请注意,对于 ASCII 表示的值,此大小与 PQfsize
报告的二进制大小无关。 .
为了声明没有固定大小的数组,您在创建数组之前使用PQgetlength
确定数组的大小。 (应该返回 19)并通过指定将数据作为文本获取 PQexecParams
有resultFormat
为 0。如果您只是使用 PQexec
则默认以文本形式返回数据。
可以使用 libpq 的示例 here .
要修改这个例子,而不只是打印值,它会根据数据的长度创建一个字符数组,并将数据复制到数组中,您可以用类似的东西替换 for 循环
for (i = 0; i < PQntuples(res); i++)
{
int length = PQgetlength(res, i, 0);
char result[length];
printf("%s\n", PQgetvalue(res, i, 0));
strncpy (result,PQgetvalue(res, i, 0),length);
}
您还需要添加 #include <string.h>
示例。
关于c - 获取 libpq-fe 中字段的大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14056894/
我正在尝试在 Ubuntu 13.10 环境中安装 pgpool-II。我正在关注 this完成它的教程。 我遇到以下错误。 configure: error: libpq is not instal
我正在使用 C++ 和 libpq(libpqxx 非常不稳定)开发高负载服务器应用程序。我在线程中使用异步查询来提高性能。但是我发现,例如,PQsendQuery("SELECT 1;SELECT
我有一个 libpq 程序,它会定期将数字插入数据库。我预计这些数字会变得相当大,它们存储在 uint64_t 类型中。我想将整数作为二进制发送到 libpq,但 Postgres 无法告诉它它是无符
这是一个愚蠢的问题。 libpq 的 PQerrorMessage 函数返回一个 char const* char const* msg = PQerrorMessage(conn); 既然它是 co
我正在为 libpq 编写一个 C++ 包装器。但是我不知道应该如何编写单元测试。我最初的 react 是将 libpq 接口(interface)包装成可模拟的东西,但这有点违背了目的。有没有人这样
我有这样的程序,可以从“C”运行。如果它们不存在,则创建一个表。 PGresult *result; conn = PG_connect(); if (conn) { if (!PG_begi
我正在编写一个用 C 封装 libpq 的库。当我执行类似 DROP SCHEMA IF EXISTS bob 的查询时,bob 不存在,libpq 输出 "NOTICE: schema "bob"
为什么下面的代码要用1.2GB的内存来执行?无论传递给 generate_series 的数量如何,我都希望内存使用量相对平稳,但它却在稳步增加。请 - 告诉我我做错了什么! if (!PQsendQ
我想知道我是否可以使用 libpq 直接从 C/C++ 进行参数化查询而不是使用字符串,如果这样做,这段代码应该是什么样子? string tblins = ""; tblins = "INSERT
所以我的 psql 表中有这个名为 rooms 的结构: Table "public.rooms"
我正在尝试将多行传递到测试表,但我无法理解它在 libpq 中究竟是如何完成的。 我找到了我认为需要的用于复制数据的命令,但没有关于如何使用它们的任何示例。 https://www.postgresq
我正在尝试安装 libpq-dev,因为 postgres 需要它,但我只收到一个错误。 pip install libpq-dev==9.4.3 Could not find a version t
我可以通过字符串操作来更新表中的记录,这有一些弱点。 所以,现在我尝试使用参数进行更新,但这并不像我想的那样。 sprintf(sql, "%s%s%s%s%s%d%s", "UPDATE "
我在使用 libpq 插入一些数据时遇到了一些困难。我有两种自定义数据类型: create type size as (width real, height real); create type ro
给定以下 libpq代码: PGconn * internalConnection = PQconnectdb("my connection string"); if (PQstatus(intern
我正在阅读 libpq 引用资料。它同时具有同步和异步方法。但是我发现了一些奇怪的事情。 当我看到PQsendQuery 函数时,它似乎发送一个查询并立即返回。我希望回调函数得到通知,但没有这样的事情
我想编写使用 Postgresql 作为 DBMS 的应用程序。要编写客户端应用程序,我需要 libpq 库和头文件吗?如果是,我将从哪里获得 libpq 库和头文件。 最佳答案 Libpq 包含在完
我想编写使用 Postgresql 作为 DBMS 的应用程序。要编写客户端应用程序,我需要 libpq 库和头文件吗?如果是,我将从哪里获得 libpq 库和头文件。 最佳答案 Libpq 包含在完
我想以非阻塞方式使用 libpq 执行 SQL 查询。因此,我希望在查询执行完毕时收到通知。 据我所知,如果我使用异步 api,libpq 会支持这一点。 使用 PQsendQuery 函数,我可以将
我遇到了 libpq 的 PQexec 功能间歇性挂起的问题连接。环顾邮件列表后,解决方案是使用异步函数 PQsendQuery/PQgetResult 并实现您自己的超时。 现在我面临的问题是 PQ
我是一名优秀的程序员,十分优秀!