Linux下
这种方法应该是最快捷解决中文乱码的办法了,不用改MySQL的编码,仅限于linux下使用:
1.在QT程序的main.cpp的main函数中QTextCodec```那三句:
intmain(intargc,char*argv[])
{
QApplication a(argc, argv);
QTextCodec *codec = QTextCodec::codecForName("UTF-8");
QTextCodec::setCodecForCStrings(codec);
QTextCodec::setCodecForTr(codec);
MainWindow w;
w.show();
returna.exec();
}
2.在你的程序代码设置数据库后添加一句: db.exec("SET NAMES 'Latin1'"); //直接使用数据库的latin1编码
以上两步就解决问题了。
Windows下
此方法修改后可以在QT中正常显示中文,也可以通过QT往MYSQL中插入中文并在QT的控件上显示出来。 但通过命令行查看表的内容时,中文直接显示为?。 所以这个办法做了之后就不能在命令行下查看mysql中文内容。
第一步把数据库的编码全部改了很重要!!
在Qt4中使用MySQL4.1及其以上版本中的中文问题解决方法
MySQL4.1及其以上版本中中文问题比较麻烦,有时候在QT中使用会出现问号或者乱码,现在说明一下在Qt中如何正确地配合使用。
先在MySQL中建表,使用中文&#x