PostgreSQL: DECLARE CURSOR failed: ERROR: invalid byte sequence for encoding "UTF8": 0xc9e3

题外:需要在VC中使用PostgreSQL,本来使用的是ODBC,因为感觉配置比较麻烦,就想使用其他方法。开始看到可以使用libpq++,但是那东西在7点几的版本后就没了;别人又说使用libpqxx,但是那几个Makefile比较难弄,好像是需要特定的VS版本来编译,所以从简就用了libpq,因为只用到简单的功能。

 

问题描述:PostgreSQL: DECLARE CURSOR failed: ERROR:  invalid byte sequence for encoding "UTF8": 0xc9e3

产生原因:因为我们用到了中文表名,所以select语句中也有了中文,在构建strSQL的时候用的是Cstring,Cstring是ascii编码的,即便加了_T("")也是UNICODE编码,所以必须要转换成UTF8编码的才能PQexec(),或者把表名改成英文的也行。

 

BTW:    int nRes = PQsetClientEncoding(conn,"SQL_ASCII");   // 设置客户端编码
            const char * chCode = pg_encoding_to_char( PQclientEncoding( conn) );          // 查看客户端编码

            这个文档很不好懂啊。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值