• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

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

    軟件測試之編程亂碼問題初步探索[2]

    發布: 2009-10-12 10:07 | 作者: 不詳 | 來源: 領測軟件測試網采編 | 查看: 13次 | 進入軟件測試論壇討論

    領測軟件測試網

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

    關鍵字:sql 那么set names是什么呢? set names實際上就是同時設置了character_set_client,character_set_connection,character_set_results這三個系統變量。

      例如set names 'gbk'等同于:

    set @@character_set_client = 'gbk'

    set @@character_set_connection = 'gbk'

    set @@character_set_results = 'gbk'

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

      因為character_set_client,character_set_connection這兩個變量僅用與保證與character_set_database編碼的一致,而character_set_results則用與保證SELECT返回的結果與程序的編碼一致。

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

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

    <?

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

    $program_char = 'utf8';

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

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

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

    {

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

    $sql = 'SELECT @@character_set_database';

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

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

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

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

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

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

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

    }

    ?>

     

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/

    TAG: 亂碼 軟件測試 探索

    21/212>

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

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>