PostgreSQL,libpq / C,更新参数

时间:2013-06-05 12:46:50

标签: postgresql libpq

我可以通过字符串操作更新表中的记录,这有一些弱点 所以,现在我尝试使用参数进行更新,但这并不像我想象的那样。

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是不适合const char数组的两倍 我只尝试使用字符串,它的工作原理。

如果我必须将数字转换为似乎不符合逻辑的字符串。

如何正确地做到这一点?

1 个答案:

答案 0 :(得分:2)

将数字转换为字符串似乎不合逻辑,但如果您使用默认的“文本”协议,那正是您必须要做的。考虑使用the libpqtypes library,它会为您处理大量此类细节。

您可以使用二进制协议(在逐个参数的基础上,参见PQexecParams上的文档)...但一般来说,使用文本协议会更好。它通常在网络上实际上更快,特别是对于许多小数字,如果使用文本协议,则不必担心字节序和数字格式问题。