首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >QT(C++)连接MySQL中文乱码解决

QT(C++)连接MySQL中文乱码解决

作者头像
静谧星空TEL
发布2021-04-27 12:27:48
发布2021-04-27 12:27:48
3.9K00
代码可运行
举报
运行总次数:0
代码可运行

1、QSqlDatabase对象设置UTF-8编码

代码语言:javascript
代码运行次数:0
运行
复制
QSqlDatabase db;
db.exec("SET NAMES 'UTF-8'");

2、将MySQL编码设置成UTF-8

代码语言:javascript
代码运行次数:0
运行
复制
show variables like 'character_set_%';
代码语言:javascript
代码运行次数:0
运行
复制
set character_set_client=utf-8;
set character_set_connection=utf-8;
set character_set_database=utf-8;
set character_set_results=utf-8;
set character_set_server=utf-8;
set collation_database = utf8mb4_unicode_ci;
set collation_connection = utf8mb4_unicode_ci;

3、MySQL的my.ini文件或my.cnf设置UTF-8

代码语言:javascript
代码运行次数:0
运行
复制
# 设置mysql客户端默认字符集
default-character-set=utf8 
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8

4、头文件设置UTF-8

代码语言:javascript
代码运行次数:0
运行
复制
#pragma execution_character_set("utf-8")

5、使用QString::fromLocal8Bit()

代码语言:javascript
代码运行次数:0
运行
复制
QString sql = QString::fromLocal8Bit("SELECT * FROM table");
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档