新手问下关于qt4和sqlite3中文显示问题!谢谢

li_rui_1220 2012-12-10 09:25:36
请问各位大侠们,qt4中使用sqlite3,创建的数据库怎么用中文比如:
query.exec("insert into person values(101, '李', '三')");
这中文是乱码!求指教
...全文
150 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
li_rui_1220 2012-12-27
  • 打赏
  • 举报
回复
query.exec(QObject::tr("insert into person values(101, '李', '三'))"); 添加头文件#include <QObject>就ok了!
jdwx 2012-12-11
  • 打赏
  • 举报
回复
每个中文字符串用QString QString::fromLocal8Bit ( const char * str, int size = -1 ) [static] 转换一下,不用设置QTextCodec。 原来是:“中文” 改为:QString::fromLocal8Bit("中文");
li_rui_1220 2012-12-11
  • 打赏
  • 举报
回复
引用 1 楼 heksn 的回复:
使用QString并设置编码方式 QString sql = QString("insert into person values(101, '李', '三')"); query.exec(sql);
亲,这样不行啊!是不是要头文件啊!!!谢了
nixy_ 2012-12-11
  • 打赏
  • 举报
回复
### std::string → QString std::string cstr; QString str; str=QStirng::fromLocal8Bit(cstr.c_str()); //可解決中文亂碼問題
yaozhiyong110 2012-12-11
  • 打赏
  • 举报
回复
可能是Qt设置的编码和数据库的编码不一致
jdwx 2012-12-11
  • 打赏
  • 举报
回复
原来是:“中文” 改为:QString::fromLocal8Bit("中文"); 哦!哈哈! 原来这么写:query.exec("insert into person values(101, '李', '三')"); 改为:query.exec("insert into person values(101, QString::fromLocal8Bit("李"), QString::fromLocal8Bit("三"))"); 这回没问题了吧!
li_rui_1220 2012-12-11
  • 打赏
  • 举报
回复
引用 3 楼 jdwx1 的回复:
每个中文字符串用QString QString::fromLocal8Bit ( const char * str, int size = -1 ) [static] 转换一下,不用设置QTextCodec。 原来是:“中文” 改为:QString::fromLocal8Bit("中文");
亲,俺没看懂
  • 打赏
  • 举报
回复
使用QString并设置编码方式 QString sql = QString("insert into person values(101, '李', '三')"); query.exec(sql);

16,212

社区成员

发帖
与我相关
我的任务
社区描述
Qt 是一个跨平台应用程序框架。通过使用 Qt,您可以一次性开发应用程序和用户界面,然后将其部署到多个桌面和嵌入式操作系统,而无需重复编写源代码。
社区管理员
  • Qt
  • 亭台六七座
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧