老司机91精品网站在线观看-老司机67194免费观看-老司国产精品视频-老熟人老女人国产老太-中文字幕日本在线-中文字幕日本一区久久

始創于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業
  • 60秒人工響應
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
您的位置: 網站首頁 > 幫助中心>文章內容

Linux與Windows下QT中使用MySQL中文亂碼解決方法

發布時間:  2012/8/21 16:51:57

Linux下

這種方法應該是最快捷解決中文亂碼的辦法了,不用改mysql的編碼,僅限于linux下使用:

1.在QT程序的main.cpp的main函數中QTextCodec```那三句:

1.int main(int argc, char *argv[])  
2.{  
3.    QApplication a(argc, argv);  
4.    QTextCodec *codec = QTextCodec::codecForName("UTF-8");   5.    QTextCodec::setCodecForCStrings(codec);  
6.    QTextCodec::setCodecForTr(codec);  
7.    MainWindow w;  
8.    w.show();  
9.    return a.exec();   10.} 
2.在你的程序代碼設置數據庫后添加一句:  db.exec("SET NAMES 'Latin1'"); //直接使用數據庫的latin1編碼

以上兩步就解決問題了。

Windows下

此方法修改后可以在QT中正常顯示中文,也可以通過QT往MYSQL中插入中文并在QT的控件上顯示出來。   但通過命令行查看表的內容時,中文直接顯示為?。 所以這個辦法做了之后就不能在命令行下查看mysql中文內容。

第一步把數據庫的編碼全部改了很重要!!

在Qt4中使用MySQL4.1及其以上版本中的中文問題解決方法

MySQL4.1及其以上版本中中文問題比較麻煩,有時候在QT中使用會出現問號或者亂碼,現在說明一下在Qt中如何正確地配合使用。

先在MySQL中建表,使用中文,一般情況下就兩種,GB(GB2312或者GBK)或者UTF8兩種。兩種的解決方法是相似的,這里我們以GBK為例說明。

一、數據庫和表以及表里的字符相關字段(varchar, char, text等)都要使用gbk_chinese_ci這種方式,不這樣做也可以,但這樣做,會省很多麻煩( 設置方法參考《MySQL統一編碼》:http://www.linuxidc.com/Linux/2011-05/35405.htm)。


二、重新編譯Qt的MySQL驅動,需要修改src/sql/drivers/mysql/qsql_mysql.cpp文件。
要修改的部分如下:第一百零八行的codec函數,注意紅色加粗部分,是我修改增加的語句。

Quote:

static QTextCodec* codec(MYSQL* mysql)
{
return QTextCodec::codecForName("GBK");
#if MYSQL_VERSION_ID >= 32321
QTextCodec* heuristicCodec = QTextCodec::codecForName(mysql_character_set_name(mysql));
if (heuristicCodec)
return heuristicCodec;
#endif
return QTextCodec::codecForLocale();
}

 

然后,重新編譯qt的mysql驅動,這里就不多說了,請查看Qt相關文檔
三、在Qt程序main函數中app后面開頭處加入下面兩句,加上這兩個是省得不必要的麻煩。

Quote:

QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"));
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("GBK"));
//QTextCodec::setCodecForTr(QTextCodec::codecForName("GBK"));


四、在Qt數據庫連接后,運行SET NAMES 'GBK'語句(紅色部分)。

Quote:

db = QSqlDatabase::addDatabase("QMYSQL");
db.setHostName("localhost");
db.setDatabaseName("yourdatabase");
db.setUserName("yourusername");
db.setPassword("yourpassword");
db.open();
db.exec("SET NAMES 'GBK'");


OK, 走過上面四步以后,我們就可以在程序中正確使用查看MySQL中的中文數據了。
但是如果你要直接通過SQL語句修改數據,則需要正確的把輸入的內容轉變為GB碼中,
比如:

Quote:

QTextCodec *codec = QTextCodec::codecForName("GBK");
QString strOut = codec->fromUnicode(lineEdit->text()).data();
QString strSql = "UPDATE user SET uinfo = '" + strOut + "'";
db.exec(strSql);


這里需要注意的是,如果設置了codecForTr也為GBK的話,那就不用上面的手動轉換步驟了,即,如果在第三步中把第三行的注釋去掉,則上面的字符串格式轉換就不需要了。

這里面最關鍵的一點就是修改qsql_mysql.cpp文件,因為它不能正確的設置codec內碼。

如果數據庫中的編碼使用的是UTF8,則把上面相關的部分改為UTF-8(Qt)或者UTF8(MySQL)就行了。


本文出自:億恩科技【www.ypdoo.com.cn】

服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經營性ICP/ISP證:贛B2-20080012
  • 服務器/云主機 24小時售后服務電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
  • 專注服務器托管17年
    掃掃關注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務熱線

     
     
    高清一级做a爱过程不卡视频| 毛片的网站| 欧美激情伊人| 午夜欧美成人久久久久久| 精品在线观看一区| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 尤物视频网站在线| 午夜欧美成人久久久久久| 午夜精品国产自在现线拍| 国产网站在线| 韩国三级香港三级日本三级| 精品国产一区二区三区久久久蜜臀 | 人人干人人插| 精品国产香蕉在线播出| 精品视频免费看| 国产亚洲精品成人a在线| 成人免费观看网欧美片| 国产a毛片| 欧美日本二区| 一级片免费在线观看视频| 青青久久网| 国产国产人免费视频成69堂| 国产麻豆精品免费视频| 91麻豆国产| 一级片免费在线观看视频| 91麻豆精品国产自产在线| 九九久久99综合一区二区| 精品久久久久久中文| 国产欧美精品| 国产成人精品综合| 精品视频在线看| 一级毛片视频播放| 国产精品自拍在线观看| 免费国产一级特黄aa大片在线| 九九精品久久久久久久久| 欧美a级v片不卡在线观看| 日韩在线观看视频黄| 欧美a级片视频| 四虎影视库| 亚洲第一页色| 欧美日本免费| 精品久久久久久免费影院| 黄视频网站在线看| 你懂的国产精品| 可以在线看黄的网站| 亚欧乱色一区二区三区| 欧美大片毛片aaa免费看| 国产一区二区高清视频| 日日爽天天| 日韩av成人| 精品久久久久久影院免费| 日韩在线观看视频黄| 精品国产香蕉伊思人在线又爽又黄| 国产一区免费在线观看| 一级女性全黄生活片免费| 日本免费乱人伦在线观看| 91麻豆精品国产自产在线| 国产成人精品综合在线| 免费毛片基地| 日本伦理网站| 二级片在线观看| 日韩男人天堂| 国产美女在线观看| 国产麻豆精品免费密入口| 欧美国产日韩一区二区三区| 精品国产一区二区三区久| 国产精品免费久久| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 99久久精品国产免费| 国产原创中文字幕| 国产91素人搭讪系列天堂| 久久精品成人一区二区三区| 国产视频一区二区在线观看| 国产视频在线免费观看| 久久国产一久久高清| 久久精品店| 韩国毛片基地| 久久国产精品永久免费网站| 一级女性全黄生活片免费| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 一级片片| 一级毛片视频播放| 成人免费一级纶理片| 99久久视频| 亚飞与亚基在线观看| 亚洲女人国产香蕉久久精品| 可以免费看污视频的网站| 日韩免费在线视频| 欧美国产日韩在线| 成人高清视频免费观看| 久久精品人人做人人爽97| 亚洲精品久久玖玖玖玖| 精品国产一区二区三区久久久狼| 天天做日日爱| 91麻豆精品国产片在线观看| 国产91精品一区| 国产精品123| 四虎影视库| 中文字幕97| 亚欧视频在线| 九九免费精品视频| 久久99这里只有精品国产| 日本特黄特黄aaaaa大片 | 精品国产三级a| 欧美a级v片不卡在线观看| 国产高清视频免费观看| 九九精品影院| 国产成人精品影视| 黄色福利| 国产亚洲免费观看| 亚洲第一页色| 你懂的日韩| 成人a大片在线观看| 沈樵在线观看福利| 欧美a级片免费看| 一级女性全黄生活片免费| 国产高清在线精品一区a| 99久久网站| 国产91丝袜在线播放0| 色综合久久天天综合观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 天天做日日干| 国产视频一区在线| 久久久久久久免费视频| 韩国毛片免费大片| 久久福利影视| 91麻豆精品国产片在线观看| 久久99中文字幕久久| 99久久网站| 国产a视频| 尤物视频网站在线| 国产亚洲免费观看| 国产a视频精品免费观看| 国产国产人免费视频成69堂| 日本在线播放一区| 久久99爰这里有精品国产| 国产美女在线一区二区三区| 亚洲第一页色| 国产不卡在线看| 亚欧乱色一区二区三区| 国产亚洲精品成人a在线| 国产福利免费观看| 91麻豆高清国产在线播放| 国产网站免费观看| 欧美激情在线精品video| 久久国产影视免费精品| 亚洲 欧美 成人日韩| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 欧美另类videosbestsex久久 | 免费毛片播放| 久久99中文字幕久久| 免费的黄色小视频| 可以在线看黄的网站| 999久久66久6只有精品| 久久久成人网| 国产视频在线免费观看| 午夜激情视频在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 99色视频在线| 成人免费高清视频| 一本高清在线| 欧美一级视| 国产一区二区精品久久91| a级黄色毛片免费播放视频| 亚洲精品久久玖玖玖玖| 欧美a免费| 国产a视频精品免费观看| 亚洲天堂在线播放| 二级片在线观看| 国产一区精品| 国产麻豆精品免费密入口| a级毛片免费观看网站| 999精品视频在线| 黄色免费三级| 亚欧乱色一区二区三区| 国产视频在线免费观看| 日韩中文字幕一区| 一级女性全黄久久生活片| 成人免费网站视频ww| 麻豆网站在线看| 麻豆网站在线看| 99久久精品费精品国产一区二区| 一级女性大黄生活片免费| 成人免费观看的视频黄页| 成人av在线播放| 美女免费精品高清毛片在线视| 精品国产一区二区三区免费 | 色综合久久天天综线观看| 青青久热| 日韩一级黄色| 可以免费看污视频的网站| 你懂的国产精品| 精品国产三级a| 国产网站在线| 午夜欧美成人香蕉剧场| 黄视频网站在线观看| 亚洲精品影院一区二区| 久久国产一区二区| 欧美一级视频免费| 久久精品免视看国产明星|