當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]環(huán)境: ?CodeGear? Delphi? 2007 for Win32?? Version 11.0.2852.9797 ,mysql 5.0.45,dbxmys30.dll(文件版本11.0.2

環(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

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開(kāi)發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開(kāi)幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉