sqlite中乱码处理

 最近在项目开发中使用到sqlite数据库,其中遇到这样一个问题,中文,英文显示正常,但一些特殊的字符显示乱码,比如 Æçæçæçæçæçæç。其实归根结底还是字符编码的问题,先前没用UTF8编码。下面来看看两种做法的异同。

一、非UTF8编码

把sql语句保存在tchar格式


然后sql执行时,使用assicc编码。




这样读取出来的结果,中文是能正常显示的,不会乱码,但特殊字符会乱码。



注: TCharToMChar是一个将TCHAR编码转化为多字节编码的方法。


二、UTF8编码

把sql语句保存在tchar格式,跟上面一样。

然后sql执行时,使用UTF8编码。




这里的UTF编码,是指sqlite3_exec函数的第二个参数,也就是sql整个语句,转变为UTF8编码,而不是把sql语句里包含的数据列数据转化为UTF8编码。这是我一直的一个误区,现在终于搞明白了。


然后在查询数据的时候也用UTF8编码。


总之,为了兼容所有的字符,直接使用UTF8编码就可,只是UTF8不是针对数据表里的数据,而是针对SQL执行语句的。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值