Qt 中存数据到数据库时存在中文乱码问题
此方法修改后可以在QT中正常显示中文,也可以通过QT往MYSQL中插入中文并在QT的控件上显示出来。 但通过命令行查看表的内容时,中文直接显示为?。 所以这个办法做了之后就不能在命令行下查看mysql中文内容。
一般这种问题主要是数据库的字符集和qt 的字符集存在不一致的问题。
在mysql的配置文件中
这里的字符集编码是utf8
所以在qt中我们要将插入的数据变成utf8
如果数据库编码是其他类型,则qt中也要进行相应的配置,
一般配置如下:
就是在打开数据库前加入
QTextCodec *codec = QTextCodec::codecForName("UTF-8");
QTextCodec::setCodecForLocale(codec);