當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(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ù)庫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

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

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

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

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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