• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            MySQL編碼機制

            大家都知道從 MySQL4.1 版本開始,支持多種編碼,包括我們熟知的 latin1gbkutf8big5 等等,還有一些我們聞所未聞的。

            在使用 PHP 連接 MySQL 查詢出來的數據有的時候居然會是亂碼,關于亂碼的解決首先我們要了解 MySQL 的編碼機制。

            Discuz! 論壇為例,Discuz! 論壇在連接 MySQL 后會立即執行一個設定(見include/db_mysql.class.php ):

            復制內容到剪貼板Code

            @mysql_query("SET character_set_connection=$dbcharset, character_set_results=$dbcharset, character_set_client=binary", $this->link);

            此三處的字符設定很大程度上會解決亂碼問題,那么這三個設定具體有什么作用呢?如果我們了解了 MySQL 的編碼機制,就可以避免在安裝插件及平時的操作過程中產生亂碼,還可以自行對論壇的數據進行轉碼。

            character_set_client 我們可以理解為 SQL 語句的編碼,如果設置為 binaryMySQL 就當二進制來處理,character_set_connection 設定的值則告訴 MySQL 用來運行 SQL 語句的時候使用的編碼,也就是說,程序發送給 MySQL SQL 語句,會首先被 MySQL character_set_client 指定的編碼轉換到 character_set_connection 指定的編碼,如果 character_set_clien 指定的是 binary ,則 MySQL 就會把 SQL 語句按照 character_set_connection 指定的編碼解釋執行。

            當執行 SQL 語句的過程中,比如向數據庫中插入取出數據的時候,字段也有編碼設置,如果字段的編碼設置和 character_set_connection 指定的不同,則 MySQL 會把插入的數據轉換成字段設定的編碼。

            SQL 執行完畢向客戶端返回數據的時候,會把數據從字段指定的編碼轉換為 character_set_results 指定的編碼,如果 character_set_results=NULL 則不做任何轉換動作,(注意這里設置為 NULL 不等于沒有設置,沒有設置的時候 MySQL 會繼承全局設置)。

            了解了 MySQL 的編碼機制,我們就可以利用這個機制進行數據的轉碼以及避免在程序使用過程中出現亂碼了。

            補充:

            mysql_query("character_set_client=gbk"); 這句告訴 MySQL 我接下來要用的 SQL 語句的編碼是 GBK

            mysql_query("character_set_connection=gbk"); 這句 告訴 MySQL 要把 SQL 語句轉換成 GBK 進行處理

            mysql_query("character_set_results=gbk"); 這句告訴 MYSQL 查詢返回的結果要統一都轉換成 GBK 編碼的

             

            posted on 2009-08-13 11:17 肥仔 閱讀(171) 評論(0)  編輯 收藏 引用 所屬分類: 數據庫

            亚洲国产精品无码久久98| 久久精品国产福利国产秒| 伊人色综合九久久天天蜜桃| 亚洲综合久久夜AV | 亚洲精品乱码久久久久久自慰| 久久久久av无码免费网 | 99久久婷婷国产一区二区| 久久久久国色AV免费看图片| 人妻无码中文久久久久专区| 久久久久亚洲精品天堂久久久久久 | 91精品国产高清91久久久久久| 精品久久久无码中文字幕| 狠狠色婷婷久久一区二区| 国内精品久久久久影院网站| 久久综合给合久久狠狠狠97色| 国产精品成人久久久久三级午夜电影| 亚洲人成精品久久久久| 久久精品一区二区影院| 国产精品一久久香蕉产线看| 午夜不卡久久精品无码免费| 精品久久久久久无码免费| 久久福利青草精品资源站免费| 亚洲女久久久噜噜噜熟女| 伊人久久大香线蕉AV一区二区| 久久综合九色综合97_久久久| 久久久一本精品99久久精品88| AV无码久久久久不卡蜜桃| 亚洲?V乱码久久精品蜜桃| 青青久久精品国产免费看| 久久久久国产视频电影| 久久人人超碰精品CAOPOREN | 久久精品aⅴ无码中文字字幕不卡| 色婷婷噜噜久久国产精品12p| 精品久久人人爽天天玩人人妻| 99精品久久久久久久婷婷| 国产精品热久久无码av| 久久国产精品免费| 亚洲国产精品无码久久九九| 亚洲国产精品成人久久蜜臀| 亚洲?V乱码久久精品蜜桃 | 少妇无套内谢久久久久|