Qt 中存数据到数据库时存在中文乱码问题

 此方法修改后可以在QT中正常显示中文,也可以通过QT往MYSQL中插入中文并在QT的控件上显示出来。   但通过命令行查看表的内容时,中文直接显示为?。 所以这个办法做了之后就不能在命令行下查看mysql中文内容。

一般这种问题主要是数据库的字符集和qt 的字符集存在不一致的问题。

在mysql的配置文件中

Qt 中存数据到数据库时存在中文乱码问题

这里的字符集编码是utf8

所以在qt中我们要将插入的数据变成utf8

如果数据库编码是其他类型,则qt中也要进行相应的配置,

一般配置如下:

Qt 中存数据到数据库时存在中文乱码问题

就是在打开数据库前加入

QTextCodec *codec = QTextCodec::codecForName("UTF-8");
    QTextCodec::setCodecForLocale(codec);