首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PostgreSQL,libpq/C,更新参数

PostgreSQL,libpq/C,更新参数
EN

Stack Overflow用户
提问于 2013-06-05 20:46:50
回答 1查看 802关注 0票数 1

我可以通过字符串操作来更新表中的记录,这有一些缺点。

所以,现在我试着用参数更新,但这并不像我想的那样。

代码语言:javascript
复制
sprintf(sql, "%s%s%s%s%s%d%s",
    "UPDATE ", mytable, " SET ",
    "my_id=$0, mystr1=$1, mystr2=$2, myint=$3, mydouble=$4",
    "WHERE my_id='", local_my_id, "'");

const char *values[5] =
{local_my_id, local_mystr1, local_mystr2, local_myint, local_mydouble};

result = PQexecParams(conn, sql, 5, NULL, values,  NULL,  NULL, 0);

值1和4是整数,值5是不适合常量字符数组的两倍。

我只对字符串进行了同样的尝试,它是有效的。

如果我必须将数字转换成看起来不符合逻辑的字符串。

如何正确地做到这一点?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-06-05 21:26:10

将数字转换为字符串似乎并不符合逻辑,但如果您使用默认的“文本”协议,那么这正是您必须要做的。考虑使用the libpqtypes library,它可以为您处理很多细节问题。

您可以使用二进制协议(在逐个参数的基础上,请参阅PQexecParams上的文档) ...但总的来说,使用文本协议要好得多。它通常在网络上更快,特别是对于许多小数字,并且如果您使用文本协议,则不必担心字符顺序和数字格式问题。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16940358

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档