<ruby id="h6500"><table id="h6500"></table></ruby>
    1. <ruby id="h6500"><video id="h6500"></video></ruby>
          1. <progress id="h6500"><u id="h6500"><form id="h6500"></form></u></progress>
            • 軟件測試技術(shù)
            • 軟件測試博客
            • 軟件測試視頻
            • 開(kāi)源軟件測試技術(shù)
            • 軟件測試論壇
            • 軟件測試沙龍
            • 軟件測試資料下載
            • 軟件測試雜志
            • 軟件測試人才招聘
              暫時(shí)沒(méi)有公告

            字號: | 推薦給好友 上一篇 | 下一篇

            軟件測試之編程亂碼問(wèn)題初步探索[2]

            發(fā)布: 2009-10-12 10:07 | 作者: 不詳 | 來(lái)源: 領(lǐng)測軟件測試網(wǎng)采編 | 查看: 13次 | 進(jìn)入軟件測試論壇討論

            領(lǐng)測軟件測試網(wǎng)

            軟件測試之編程亂碼問(wèn)題初步探索[2]   軟件測試工具

            關(guān)鍵字:sql 那么set names是什么呢? set names實(shí)際上就是同時(shí)設置了character_set_client,character_set_connection,character_set_results這三個(gè)系統變量。

              例如set names 'gbk'等同于:

            set @@character_set_client = 'gbk'

            set @@character_set_connection = 'gbk'

            set @@character_set_results = 'gbk'

              很多情況下,這樣設置了之后就能把亂碼問(wèn)題解決了。但是還是不能完全避免出現亂碼的可能,為什么呢?

              因為character_set_client,character_set_connection這兩個(gè)變量?jì)H用與保證與character_set_database編碼的一致,而character_set_results則用與保證SELECT返回的結果與程序的編碼一致。

              例如,你的數據庫(character_set_database)用的是utf8的字符集,那么你就要保證character_set_client,character_set_connection也是utf8的字符集。而你的程序也許采用的并不是utf8,比如你的程序用的是gbk,那么你若把character_set_results也設置為utf8的話(huà)就會(huì )出現亂碼問(wèn)題。此時(shí)你應該把character_set_results設置為gbk。這樣就能保證數據庫返回的結果與你的程序的編碼一致。

              下面我給出一段用于設置字符集的代碼(其中用到了一個(gè)我自己寫(xiě)的db庫,相信應該不影響閱讀):

            <?

            //假設我們的程序采用的是utf8的字符集

            $program_char = 'utf8';

            //先檢查mysql的版本號,如果版本號大于4我們才可以設置這些系統變量(mysql4還沒(méi)有這些系統變量)

            $version = current($db->fetch_one('SELECT VERSION()'));

            if (substr($version, 0, 1) > 4)

            {

            //取出當前數據庫的字符集

            $sql = 'SELECT @@character_set_database';

            $char = current($db->fetch_one($sql));

            //將客戶(hù)端字符集(character_set_client)和

            連接字符集(character_set_connection)設置為與數據庫字符集(character_set_database)一致

            $db->query('SET @@character_set_client = "' . $char . '"');

            $db->query('SET @@character_set_connection = "' . $char . '"');

            //將SELECT查詢(xún)返回數據的字符集設置為與當前程序的字符集一致

            $db->query('SET @@character_set_results = "' . $program_char . '"');

            }

            ?>

             

            延伸閱讀

            文章來(lái)源于領(lǐng)測軟件測試網(wǎng) http://kjueaiud.com/

            TAG: 亂碼 軟件測試 探索

            21/212>

            關(guān)于領(lǐng)測軟件測試網(wǎng) | 領(lǐng)測軟件測試網(wǎng)合作伙伴 | 廣告服務(wù) | 投稿指南 | 聯(lián)系我們 | 網(wǎng)站地圖 | 友情鏈接
            版權所有(C) 2003-2010 TestAge(領(lǐng)測軟件測試網(wǎng))|領(lǐng)測國際科技(北京)有限公司|軟件測試工程師培訓網(wǎng) All Rights Reserved
            北京市海淀區中關(guān)村南大街9號北京理工科技大廈1402室 京ICP備2023014753號-2
            技術(shù)支持和業(yè)務(wù)聯(lián)系:info@testage.com.cn 電話(huà):010-51297073

            軟件測試 | 領(lǐng)測國際ISTQBISTQB官網(wǎng)TMMiTMMi認證國際軟件測試工程師認證領(lǐng)測軟件測試網(wǎng)

            老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月
              <ruby id="h6500"><table id="h6500"></table></ruby>
              1. <ruby id="h6500"><video id="h6500"></video></ruby>
                    1. <progress id="h6500"><u id="h6500"><form id="h6500"></form></u></progress>