QT 查询 sqlite 中文数据乱码问题。

yyps 2018-11-13 11:50:52
db文件是由其他程序写入的,应该是按ANSI字符集写入的,QT 读取中文数据乱码,尝试了N中转换后未解决。上部分demo代码:



QString ckPath = "e:\\ck.db";
QSqlDatabase db = QSqlDatabase :: addDatabase("QSQLITE");
db.setDatabaseName(ckPath);
do
{
if (!db.open()){
qDebug() << QObject::tr("ck open failed!");
break;
}
qDebug() << QObject::tr("ck open success!");

QSqlQuery sqlQuery;
QString create_sql = "select ksxm from student where sfzh='220122198805045910'";
sqlQuery.prepare(create_sql);
if (!sqlQuery.exec()) {
qDebug() << "Error: Fail to search." << sqlQuery.lastError();
break;
}

while (sqlQuery.next()){
QString ksxm = sqlQuery.value(0).toString();
qDebug()<<QString("ksxm:%1").arg(ksxm);
}
} while (0);
db.close();

...全文
534 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
走好每一步 2018-11-19
  • 打赏
  • 举报
回复
理解编码的本质,就不会存在乱码了。
云山大侠 2018-11-15
  • 打赏
  • 举报
回复
toutf18

16,215

社区成员

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

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