phpmyadmin中亂碼很通俗的解釋和解決方法
在做專案遇到.net連線mysql亂碼問題,和虛擬主機的服務商溝通,他們不讓改my.ini檔案,非常非常的來火,可是又沒辦法。但是之前沒接觸過類似的問題,一直解決不了,然後一直找了很久,看到這篇文章,來了靈感,在連線前設定set names 'utf8',可還是不行,最後在web.config裡面的連線字串裡面,假如charset=utf8,一試,終於可以了。
終於丟下了心中的大石,37xxx,你把我整的好苦啊!!!
下面是查詢到的資料:
------------------------------------------------------------------------------------------------------------------------
和字元相關的變數中這幾個和sql很有關係:
character_set_client
character_set_connection
character_set_results
此外就是資料庫中對相應欄位設定的charact set,如果沒有對欄位設定,預設是table的charact set,table也沒有指定則預設使用database的。
上面3個變數的作用是這樣的,client表示客戶端傳送過來的字符集,results表示傳送到客戶端的字符集(這兩個分開是因為傳送過來和傳送過去的不一定是同一個客戶端),connection則在客戶端和資料庫起一個連線作用。
具體是這樣:比如我在mysql命令列設定client為gbk,connection為utf8,results為gbk,資料庫為big5,
當我傳送一個insert語句的時候,這個語句作為gbk程式碼,先轉為utf8程式碼(connection),再轉為big5(database)插入資料庫。
而執行一個select語句的時候,從資料庫得到的結果則相反的過程,由big5轉為utf8,再轉為gbk,你得到gbk的結果。
因此最主要的是讓client和results和你使用的客戶端一致。比如你的網頁是utf8編碼,你就要設定這兩個為utf8。
而在mysql命令列的時候,我用的是2000,需要設定為gbk
而我們用的set names XXX,實際上就是同時設定這3個變數為XXX。
在這樣的情況下,我們可以把一個數據庫中的不同表或不同欄位設為不同的字符集,只要上面3個設定正確,就可以在資料庫中同時使用不同的字符集。
注意要保證你的資料庫中的字元已經使用了正確的字符集,比如如果一開始你設定錯誤,插入資料後,本身資料的編碼就是不正確的,然後即使設定改回來,也不可能得到正確的顯示了。
還有一個是編碼互相之間的相容性,如果一個字元在gbk中有,在utf8中沒有,那麼在gbk-》utf8-》gbk的過程中,它就變成了“?”
——————————————————————————————-
再說一下具體解決的辦法。
首先要指定你的升級後的database及table及field的character set,一般來說我們用gb2312或者utf8的,如果不同時使用多種編碼,只要指定database就可以,可以在建庫的sql語句加上相應的character set,在phpMyAdmin裡也可以修改。
然後是匯入舊資料。首先要確定自己的資料檔案的編碼。如果用phpMyAdmin匯入,在介面上有檔案編碼的選項,一定要和資料檔案的編碼一致。
如果從mysql的命令列匯入,就要自己設定上面說到的3個變數,set names xxx。
使用其它的客戶端程式一樣要注意。
這樣就可以讓舊資料轉入新資料庫後的編碼才是正確的,如果這一步錯了,後面不可能得到正確的顯示。
然後是自己的程式,在連線後就可以執行一次set names xxx,根據你的網頁編碼而定。
這樣基本就可以保證編碼正確了。
轉載一篇javeeye上的文章作為補充:
———————————————————
MySQL的字符集支援(Character Set Support)有兩個方面:字符集(Character set)和排序方式(Collation)。對於字符集的支援細化到四個層次:
伺服器(server),資料庫(database),資料表(table)和連線(connection)。
1.MySQL預設字符集:MySQL對於字符集的指定可以細化到一個數據庫,一張表,一列.傳統的程式在建立資料庫和資料表時並沒有使用那麼複雜的配置,它們用的是預設的配置. (1)編譯MySQL 時,指定了一個預設的字符集,這個字符集是 latin1;(2)安裝MySQL 時,可以在配置檔案 (my.ini) 中指定一個預設的的字符集,如果沒指定,這個值繼承自編譯時指定的;(3)啟動mysqld 時,可以在命令列引數中指定一個預設的的字符集,如果沒指定,這個值繼承自配置檔案中的配置,此時 character_set_server 被設定為這個預設的字符集;(4)當建立一個新的資料庫時,除非明確指定,這個資料庫的字符集被預設設定為character_set_server;(5)當選定了一個數據庫時,character_set_database 被設定為這個資料庫預設的字符集;(6)在這個資料庫裡建立一張表時,表預設的字符集被設定為 character_set_database,也就是這個資料庫預設的字符集;(7)當在表內設定一欄時,除非明確指定,否則此欄預設的字符集就是表預設的字符集;如果什麼地方都不修改,那麼所有的資料庫的所有表的所有欄位的都用
latin1 儲存,不過我們如果安裝 MySQL,一般都會選擇多語言支援,也就是說,安裝程式會自動在配置檔案中把 default_character_set 設定為
UTF-8,這保證了預設情況下,所有的資料庫的所有表的所有欄位的都用 UTF-8 儲存。
2.檢視預設字符集(預設情況下,mysql的字符集是latin1(ISO_8859_1)通常,檢視系統的字符集和排序方式的設定可以通過下面的兩條命令:
mysql> SHOW VARIABLES LIKE ‘character%’;
+————————–+———————————+
| 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:”mysql-5.0.37″share”charsets” |
+————————–+———————————+
mysql> SHOW VARIABLES LIKE ‘collation_%’;
+———————-+—————–+
| Variable_name | Value |
+———————-+—————–+
| collation_connection | utf8_general_ci |
| collation_database | utf8_general_ci |
| collation_server | utf8_general_ci |
+———————-+—————–+
3.修改預設字符集
(1) 最簡單的修改方法,就是修改mysql的my.ini檔案中的字符集鍵值,
如 default-character-set = utf8
character_set_server = utf8
修改完後,重啟mysql的服務,service mysql restart
使用 mysql> SHOW VARIABLES LIKE ‘character%’;檢視,發現數據庫編碼均已改成utf8
+————————–+———————————+
| Variable_name | Value |
+————————–+———————————+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | D:”mysql-5.0.37″share”charsets” |
+————————–+———————————+
(2) 還有一種修改字符集的方法,就是使用mysql的命令
mysql> SET character_set_client = utf8 ;
mysql> SET character_set_connection = utf8 ;
mysql> SET character_set_database = utf8 ;
mysql> SET character_set_results = utf8 ;
mysql> SET character_set_server = utf8 ;
mysql> SET collation_connection = utf8 ;
mysql> SET collation_database = utf8 ;
mysql> SET collation_server = utf8 ;
一般就算設定了表的預設字符集為utf8並且通過UTF-8編碼傳送查詢,你會發現存入資料庫的仍然是亂碼。問題就出在這個connection連線層上。解決方法是在傳送查詢前執行一下下面這句:
SET NAMES ‘utf8′;
它相當於下面的三句指令:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;