解決delphi2007下dbexpress連mysql5時中文顯示亂碼(文中有可連非默認端口的方法)
環(huán)境: ?CodeGear? Delphi? 2007 for Win32?? Version 11.0.2852.9797 ,mysql 5.0.45,dbxmys30.dll(文件版本11.0.2852.9797),libmysql.dll(mysql5自帶,大小1.94 MB (2,035,712 字節(jié))) 數(shù)據(jù)庫test,表user? CREATE TABLE `user` ( ?`id` int(11) default NULL, ?`name` varchar(20) default NULL ) 1,字符集問題 myql5安裝默認用的是latin1字符集,我們一般都會用utf-8、GBK、gb2312等的字符集,這里只講latin1和gb2312。 latin1:
很簡單,用默認的連法,輕松的實現(xiàn)就可以輸入中文,正確顯示中文(有些字符可能會有些問題,如:兩不同的漢字,在mysql中可能認為是同一個)。按默認配置安裝mysql5完后,在MySQL Command Line Client下用show variables like "c%"查看字符集情況,從圖中看出客戶端,服務(wù)端用的都是latin1字符集。
如圖:
運行演示程序,插入兩條記錄,并提交。如圖:
回到MySQL Command Line Client下,執(zhí)行select * from user。如圖:
一切正常。
gb2312:
用mysql5的MySQL Server Instance Config Wizard工具把mysql的字符集指定為gb2312。再次在MySQL Command Line Client下用show variables like "c%" 查看字符集情況,從圖中看出客戶端,服務(wù)端用的都是gb2312字符集。如圖:
?
查看以前的數(shù)據(jù)select * from user;,返回的數(shù)據(jù)中漢字顯示為亂碼。接下來看一下是否能正常插入,執(zhí)行插入語句insert into user value (3,"看到亂馬了嗎?");?? 執(zhí)行報錯,無法插入。這是怎么回事,為了深入了解,我們查看表user狀態(tài)show table status;。如圖:
? 從圖中看出表user的Create_options 為latin1_swdish_ci。用EMS.SQL.Manager.2005(下面都用簡稱EMS)一看表的結(jié)構(gòu):
CREATE TABLE `user` ( ?`id` int(11) default NULL, ?`name` varchar(20) default NULL ) ENGINE=MyISAM DEFAULT CHARSET=latin1; 表user的字符集還是latin1, 運行演示程序,從程序上面的gride看得出鏈接mysql時dbexpress客戶端的字符集為latin1,服務(wù)端的為gb2312,跟MySQL Command Line Client上返回的數(shù)據(jù)不一樣,但是漢字顯示正常,插入一條數(shù)據(jù)看看,沒問題。如圖:? 回到MySQL Command Line Client,執(zhí)行select * from user;,結(jié)果新加的數(shù)據(jù)中漢字還是為一些亂碼。如圖:
? 這里由于演示程序客戶端用的字符集跟user表的字符集相同,所以數(shù)據(jù)能夠順利插入。
但是,我們現(xiàn)在期望的是用一個真正使用gb2312字符集的表。下面我們改變一下user表的結(jié)構(gòu) 執(zhí)行alter table user charset =gb2312;?用EMS再看表的結(jié)構(gòu): CREATE TABLE `user` ( ?`id` int(11) default NULL, ?`name` varchar(20) character set latin1 default NULL ) ENGINE=MyISAM DEFAULT CHARSET=gb2312;
name這個字段的字符集還是為latin1。繼續(xù)改變,執(zhí)行alter table change name name varchar(20) character set gb2312 default NULL; 執(zhí)行時報錯,如圖:
? 對于已經(jīng)存在數(shù)據(jù)的表,轉(zhuǎn)換字段的字符集,還是有些麻煩的。(建議:1按特殊的方法導(dǎo)出數(shù)據(jù),2把表清空,3改變字段的字符集,4導(dǎo)入數(shù)據(jù)到表中)。在這里為了方便,我們直接清空數(shù)據(jù)delete from user; ,接著 alter table user change name name varchar(20) character set gb2312 default NULL; 執(zhí)行成功。插入一條數(shù)據(jù)看看insert into user value (3,"看到亂馬了嗎?"); 查詢結(jié)果select * from user;如圖:
? 這回cmd下顯示正常了。
回到演示程序,我們期待的“亂馬”來了。如圖:? 插入一條數(shù)據(jù)看看,噢,delphi2007報了一個意外錯誤。如圖:? 當(dāng)然這個錯誤不會返回給用戶的,就好像成功插入了一樣,如圖:? 我們點刷新按鈕看看,用戶得到了一個警告。如圖:為了確定數(shù)據(jù)是否被插入,我們回到MySQL Command Line Client,執(zhí)行select * from user; ?如圖:? 數(shù)據(jù)記錄沒有增加。怎么辦?統(tǒng)一客戶端和服務(wù)端的字符集。 服務(wù)端已經(jīng)設(shè)好了gb2312的字符集?,F(xiàn)在就剩delphi這塊了。 在TSQLConnection的屬性params增加一行參數(shù)ServerCharset=gb2312 ? 點開params屬性? 點擊Code Editor,多個端口屬性??其實我裝的時候把端口改為3307,呵呵,為的就是順便講訪問非默認端口 添加ServerCharset=gb2312端口可以在這里設(shè)。 ? 運行演示程序,添加一條記錄,成功。如圖:這次跟MySQL Command Line Client上返回的數(shù)據(jù)一樣了,如圖:? 2,端口問題 在TSQLConnection的屬性params增加一行參數(shù)Port=xxxx?(xxxx為端口數(shù)字)。 上面已經(jīng)提到,不再貼圖。這個方法不適用于delphi7。。已經(jīng)測試過。 ? ? 相關(guān)連接: 我是在csdn社區(qū)C++ Buider版塊的“茶館”找到這個帖子的:《放棄DBExpress,真爛!還是用ADO成熟點!》 http://topic.csdn.net/u/20070810/14/1963df50-0e5d-46b6-9f3a-f137c735a7d0.html 此帖有borland版塊重要人物出場 李維(不知是真的不?),僵哥等. 擴展信息: D2007 用dbexpress 連接mysql 發(fā)布程式后發(fā)生"災(zāi)難性故障"---(萬惡的xp ? 防火墻) http://topic.csdn.net/u/20071031/15/ca6baa0f-f983-483d-a3f0-9a9b2f2cc64f.html