sqlite中文乱码问题原因分析及解决


在VC++中通过sqlite3.dll接口对sqlite数据库进行操作,包括打开数据库,插入,查询数据库等,如果操作接口输入参数包含中文字符,会导致操作异常。例如调用sqlite3_open打开数据库文件,如果文件路径出现中文,就会导致打开失败。sqlite3_exec执行sql语句,如果包含中文对应字符就会变成乱码。

这是由于sqlite数据库使用的是UTF-8编码方式,而传入的字符串是ASCII编码或Unicode编码,导致字符串格式错误。解决方案是在调用sqlite接口之前,先将字符串转换成UTF-8编码,以下提供各种字符串编码转换函数。

复制代码 代码如下:

//UTF-8转Unicode
std::wstring Utf82Unicode(const std::string& utf8string)
{
int widesize = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, NULL, 0);
if (widesize == ERROR_NO_UNICODE_TRANSLATION)
{
throw std::exception("Invalid UTF-8 sequence.");
}
if (widesize == 0)
{
throw std::exception("Error in conversion.");
}
std::vector<wchar_t> resultstring(widesize);
int convresult = ::MultiByteToWideChar(CP_UTF8, 0, utf8string.c_str(), -1, &resultstring[0], widesize);
if (convresult != widesize)
{
throw std::exception("La falla!");
}
return std::wstring(&resultstring[0]);
}
//unicode 转为 ascii
string WideByte2Acsi(wstring& wstrcode)
{
int asciisize = ::WideCharToMultiByte(CP_OEMCP, 0, wstrcode.c_str(), -1, NULL, 0, NULL, NULL);
if (asciisize == ERROR_NO_UNICODE_TRANSLATION)
{
throw std::exception("Invalid UTF-8 sequence.");
}
if (asciisize == 0)
{
throw std::exception("Error in conversion.");
}
std::vector<char> resultstring(asciisize);
int convresult =::WideCharToMultiByte(CP_OEMCP, 0, wstrcode.c_str(), -1, &resultstring[0], asciisize, NULL, NULL);
if (convresult != asciisize)
{
throw std::exception("La falla!");
}
return std::string(&resultstring[0]);
}
//utf-8 转 ascii
string UTF_82ASCII(string& strUtf8Code)
{
string strRet("");
//先把 utf8 转为 unicode
wstring wstr = Utf82Unicode(strUtf8Code);
//最后把 unicode 转为 ascii
strRet = WideByte2Acsi(wstr);
return strRet;
}
///////////////////////////////////////////////////////////////////////
//ascii 转 Unicode
wstring Acsi2WideByte(string& strascii)
{
int widesize = MultiByteToWideChar (CP_ACP, 0, (char*)strascii.c_str(), -1, NULL, 0);
if (widesize == ERROR_NO_UNICODE_TRANSLATION)
{
throw std::exception("Invalid UTF-8 sequence.");
}
if (widesize == 0)
{
throw std::exception("Error in conversion.");
}
std::vector<wchar_t> resultstring(widesize);
int convresult = MultiByteToWideChar (CP_ACP, 0, (char*)strascii.c_str(), -1, &resultstring[0], widesize);
if (convresult != widesize)
{
throw std::exception("La falla!");
}
return std::wstring(&resultstring[0]);
}
//Unicode 转 Utf8
std::string Unicode2Utf8(const std::wstring& widestring)
{
int utf8size = ::WideCharToMultiByte(CP_UTF8, 0, widestring.c_str(), -1, NULL, 0, NULL, NULL);
if (utf8size == 0)
{
throw std::exception("Error in conversion.");
}
std::vector<char> resultstring(utf8size);
int convresult = ::WideCharToMultiByte(CP_UTF8, 0, widestring.c_str(), -1, &resultstring[0], utf8size, NULL, NULL);
if (convresult != utf8size)
{
throw std::exception("La falla!");
}
return std::string(&resultstring[0]);
}
//ascii 转 Utf8
string ASCII2UTF_8(string& strAsciiCode)
{
string strRet("");
//先把 ascii 转为 unicode
wstring wstr = Acsi2WideByte(strAsciiCode);
//最后把 unicode 转为 utf8
strRet = Unicode2Utf8(wstr);
return strRet;
}



相关阅读:
Yii2分页的使用及其扩展方法详解
浅谈three.js中的needsUpdate的应用
基于Jquery+Ajax+Json实现分页显示附效果图
PHP编写文件多服务器同步程序
在Linux下使用avconv进行屏幕录像的教程
引入autocomplete组件时JS报未结束字符串常量错误
Android实现获取签名及公钥的方法
讲解Java中的基础类库和语言包的使用
IOS如何在Host App 与 App Extension 之间发送通知
java编写贪吃蛇小游戏
Win10桌面屏幕不断忽闪忽现出现闪屏bug该怎么办?
jQuery实现提示密码强度的代码
javascript从右边截取指定字符串的三种实现方法
详解ASP.NET中Session的用法
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 《首义精神耀千秋》读后感800字 游玩大佛寺300字 2006年机关效能建设工作总结 禅师 利令智昏造句 小猪闯祸作文400字 社会主义核心价值观演讲稿_1500字 老师,我要对你说500字 政府采购中心治理商业贿赂自查自纠情况汇报 受骗以后作文1000字 读《我的油布伞》有感作文450字 我那老家 成长中她牵着我们的手作文700字 欢乐的森林300字 巧遇鲁西西800字 游园不惊 教师我的中国梦演讲稿 东野圭吾《杀人之门》读后感 感人的镜头作文650字 计算机开发与应用求职信范文 哈佛女生创业:去中国青海开发牦牛 圣诞节祝福语藏头诗 我喜欢的一句名言 作文 作家进校园作文 高中高二作文1000字:我最喜欢的小物品 奥运五福娃 妈妈 我爱你作文450字 经典励志故事:低姿态_励志故事 绝望人 好看的励志电影排行榜 甜品店商业策划书 牟阿姨 播种作文650字 组工干部学习《准则》和《条例》心得体会2篇 2013六年级上册语文第一单元复习资料及复习试题 接手 不同情境中的礼貌用语 2012—2013学年度学校后勤工作总结 第一次独自在家作文300字 热爱生命的仙人掌_第五单元作文 《超能陆战队》影评 励志寓言故事《杞人忧天》 求职信范文(汽车工程专业) 人生,这样更幸福:网友原创日志 高中高一作文900字:I Am the Winner-我是赢家 更要注重把握政策——六论第二批保持共产党员先进性教育活动 关于自信的作文 拓展训练项目策划书 杂诗四首·抱薰心常焦 崔永元:保持微微的愤怒 检察机部门践行科学发展观关心民生调研思考

Copyright © 2016 phpStudy |