日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > > 充電吧
[導(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,字符集問題 myql5安裝默認(rèn)用的是latin1字符集,我們一般都會(huì)用utf-8、GBK、gb2312等的字符集,這里只講latin1和gb2312。 latin1:

很簡(jiǎn)單,用默認(rèn)的連法,輕松的實(shí)現(xiàn)就可以輸入中文,正確顯示中文(有些字符可能會(huì)有些問題,如:兩不同的漢字,在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ù)中漢字顯示為亂碼。接下來看一下是否能正常插入,執(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ù)看看,沒問題。如圖:? 回到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下顯示正常了。

回到演示程序,我們期待的“亂馬”來了。如圖:? 插入一條數(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ù)記錄沒有增加。怎么辦?統(tǒng)一客戶端和服務(wù)端的字符集。 服務(wù)端已經(jīng)設(shè)好了gb2312的字符集?,F(xiàn)在就剩delphi這塊了。 在TSQLConnection的屬性params增加一行參數(shù)ServerCharset=gb2312 ? 點(diǎn)開params屬性? 點(diǎn)擊Code Editor,多個(gè)端口屬性??其實(shí)我裝的時(shí)候把端口改為3307,呵呵,為的就是順便講訪問非默認(rèn)端口 添加ServerCharset=gb2312端口可以在這里設(shè)。 ? 運(yùn)行演示程序,添加一條記錄,成功。如圖:這次跟MySQL Command Line Client上返回的數(shù)據(jù)一樣了,如圖:? 2,端口問題 在TSQLConnection的屬性params增加一行參數(shù)Port=xxxx?(xxxx為端口數(shù)字)。 上面已經(jīng)提到,不再貼圖。這個(gè)方法不適用于delphi7。。已經(jīng)測(cè)試過。 ? ? 相關(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)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問題卻十分常見,不僅增加了維護(hù)成本,還影響了用戶體驗(yàn)。要解決這一問題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉