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