首頁 >後端開發 >php教程 >小結下MySQL中文亂碼,phpmyadmin亂碼,php亂碼 產生原因及其解決方法第1/3頁

小結下MySQL中文亂碼,phpmyadmin亂碼,php亂碼 產生原因及其解決方法第1/3頁

WBOY
WBOY原創
2016-07-29 08:37:07910瀏覽

亂碼產生原因 
mysql字元編碼是版本4.1引入的,支援多國語言,而且一些特性已經超過了其他的資料庫系統。
我们可以在MySQL Command Line Client 下输入如下命令查看mysql的字符集
mysql> SHOW CHARACTER SET;
+----------+-----------------------------+---------------------+--------+
| Charset  | Description                 | Default collation   | Maxlen |
+----------+-----------------------------+---------------------+--------+
| big5     | Big5 Traditional Chinese    | big5_chinese_ci     | 2      |
| dec8     | DEC West European           | dec8_swedish_ci     | 1      |
| cp850    | DOS West European           | cp850_general_ci    | 1      |
| hp8      | HP West European            | hp8_english_ci      | 1      |
| koi8r    | KOI8-R Relcom Russian       | koi8r_general_ci    | 1      |
| latin1   | cp1252 West European        | latin1_swedish_ci   | 1      |
| latin2   | ISO 8859-2 Central European | latin2_general_ci   | 1      |
| swe7     | 7bit Swedish                | swe7_swedish_ci     | 1      |
| ascii    | US ASCII                    | ascii_general_ci    | 1      |
| ujis     | EUC-JP Japanese             | ujis_japanese_ci    | 3      |
| sjis     | Shift-JIS Japanese          | sjis_japanese_ci    | 2      |
| hebrew   | ISO 8859-8 Hebrew           | hebrew_general_ci   | 1      |
| tis620   | TIS620 Thai                 | tis620_thai_ci      | 1      |
| euckr    | EUC-KR Korean               | euckr_korean_ci     | 2      |
| koi8u    | KOI8-U Ukrainian            | koi8u_general_ci    | 1      |
| gb2312   | GB2312 Simplified Chinese   | gb2312_chinese_ci   | 2      |
| greek    | ISO 8859-7 Greek            | greek_general_ci    | 1      |
| cp1250   | Windows Central European    | cp1250_general_ci   | 1      |
| gbk      | GBK Simplified Chinese      | gbk_chinese_ci      | 2      |
| 拉丁5   | ISO 8859-9 土耳其語          | latin5_turkish_ci   | 1      |
| Armscii8 | ARMSCII-8 亞美尼亞語          | Armscii8_general_ci | | 1      |
| utf8     | UTF-8 Unicode               | utf8_general_ci     | 3      |
 ucs2     | UCS-2 Unicode               | ucs2_general_ci    俄語                 | cp866_general_ci    | 1      1      |
| 麥斯| Mac 中歐|       | macce_general_ci    | 1      |
|      |
| cp852    | DOS 中歐        | cp852_general_ci    | 1  cp852_general_ci    | 1           | latin7_general_ci   | 1      |
| cp1251   | Windows 西里爾文            | cp1251_general_ci   | 1      |
| cp1256   | Windows 阿拉伯語              | cp1256_general_ci   | 1      |
| cp1257   | Windows 波羅的海|              | cp1257_general_ci   | 1      |
卷       | geostd8_general_ci | | 1      |
| cp932    | SJIS eucjpms | UJIS Windows 版日文版| eucjpms_japanese_ci | | 3      |
+----------+---------------------- -------------------+----- ----------------+-------- +
集合中36行(0.02秒)
更多mysql的字符集知識可以參考本論壇的
http://www.phpfans.net/bbs/viewt ... &extra=page% 3D1
或mysql官方的
http://dev.mysql.com/doc/refman/ 5.1/zh/charset.html
MySQL 4.1的字元集支援(Character Set Support)有兩個面向:字元集(Character set)和排序方式(Collat​​e)。對於字元集的支援細化到四個層次:伺服器(伺服器),資料庫(資料庫),資料表(表)和連接(連接)。
查看系統的字元集和排序方式的設定可以透過下面的兩個指令:
mysql> SHOW VARIABLES LIKE 'character_set_%';
+----------- ---------------+------------------------------------------------ ---------+
| Variable_name            | Value              🎜>+----------------------------------------+- ------------------------------------------+
| character_set_client     | latin1 |
| character_set_connection | latin1                                    |
| character_set_database   | latin1                                    |
| character_set_filesystem | binary                                    |
| character_set_results    | latin1                                    |
| character_set_server     | latin1                                    |
| character_set_system     | utf8                                      |
| character_sets_dir       | D:MySQLMySQL Server 5.0sharecharsets |
+--------------------------+------- --------------------------------------+
8 rows in set (0.06 sec)
mysql> SHOW VARIABLES LIKE 'collat​​ion_%';
+----------------------+------------ -------+
| Variable_name        | Value             |
+----------------------------------+------ ------------+
| collat​​ion_connection | latin1_swedish_ci |
| collat​​ion_database   | latin1_swedish_ci | 3 rows in set (0.02 sec)
上列出的值就是系統的預設值。 latin1預設校對規則是latin1_swedish_ci,預設是latin1的瑞典語排序方式.
為什麼呢默認會是latin1_swedish_ci呢,追溯一下mysql歷史很容易發現
1979年,一家瑞典公司Tcx欲開發一個快速的多線程、多用戶資料庫系統。 Tcx 公司起初想利用mSQL和他們自己的快速低階例程 (Indexed Sequential Access Method,ISAM)去連接資料庫表,然而,在一些測試以後得出結論:mSQL對其需求來說不夠快速和靈活。這就產生了一個連接器資料庫的新SQL接口,它使用幾乎和mSQL一樣的API介面。這個API被設計成可以讓那些由mSQL而寫的第三方程式碼更容易移植到MySQL。
相信如果mysql是中國開發的,那麼漢語也是預設編碼了
當然我們也可以自己需要修改mysql的預設字元集
在mysql配置文檔my.ini,找到如下兩句:
[mysql]
default-character-set=latin1

# created and no character set is defined
default-character-set=latin1
修改後面的值就可以修改後面的值就可以修改後面的值就可以修改後面的值就可以修改。
這裡不建議改,仍保留預設值
也就是說啟動 mysql時,如果沒指定指定一個預設的字元集,這個值繼承自設定檔中的; 
此時 character_set_server 被設設定為這個預設的字元集; 當建立一個新的資料庫時,
除非明確指定,這個資料庫的字元集被缺省設定為 character_set_server; 當選定了一個資料庫時,
character_set_database 被設定定為這個資料庫預設的字元集; 在這個資料庫裡建立一張表時,
表預設的字元集被設定為 character_set_database,也就是這個資料庫預設的字元集; 
當在表內設定一欄時,除非明確指定,否則此欄缺省的字元集就是表格預設的字元集。
這樣問題就隨之而來了,假如一資料庫是gbk編碼。如果存取資料庫時沒指定其的字元集是gbk。
那麼這個值將繼承系統的latin1,這樣就做成mysql中文亂碼。
亂碼解決方法
要解決亂碼問題,首先必須弄清楚自己資料庫用什麼編碼。如果沒有指明,將是預設的latin1。
我們用得最多的應該是這3種字符集 gb2312,gbk,utf8。
那我們要如何去指定資料庫的字元集呢?以下也gbk為例
【在MySQL Command Line Client建立資料庫 】
mysql> CREATE TABLE `mysqlcode` (
   Y KEY ,
-> `content` VARCHAR( 255 ) NOT NULL
    -> ) TYPE = MYISAM CHARACTER SET gbk (0.03 sec)

當前1 /3頁 123下一頁

以上就介紹了 小結下MySQL中文亂碼,phpmyadmin亂碼,php亂碼 產生原因及其解決方法第1/3頁,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn