各版本mysql亂碼的問題解決(轉)

  以前用的是ubuntu系統,直接從Mysql官網下載Mysql5.5源碼編譯,但老是沒法經過,因此最後只得經過ubuntu的軟件源安裝,源的 Mysql版本是5.1.那個亂碼問題基本好解決,可是最後換到fedora15系統後,從源安裝Mysql版本是5.5,安裝好後發現中文會出現?代 替,查看後發現character_set_server和character_set_database字符集還是latin1,可是安裝網上的辦法修 改my.cnf後數據庫啓動就會失敗,恢復my.cnf文件後就能正常啓動。因此在這總結如下mysql的亂碼問題。       首先一點是,Mysql字符集設置分爲服務器級,數據庫級,表級和字段級四級。你能夠在建表的時候爲表或者字段指定單獨使用的字符集。可使用show create table TableName 或 show full columns from tableName 命令查看指定表或者表中字段所使用的字符集,之因此中文會亂碼,就是由於使用了Mysql時可能使用了不支持中文的字符集。       在mysql中使用命令show variables like 'char%'會獲得一個結果,例如我在未修改字符集以前,我電腦的結果爲: mysql> show variables like 'char%'; +--------------------------+---------------- | Variable_name            | Value +--------------------------+---------------- | character_set_client     | utf8 | character_set_connection | utf8 | character_set_database   | latin1 | character_set_filesystem | binary | character_set_results    | utf8 | character_set_server     | latin1 | character_set_system     | utf8 | character_sets_dir       | /usr/share/mysql/charsets/ +--------------------------+---------------- 8 rows in set (0.00 sec) mysql>     所以你要讓整個數據庫默認支持中文,須要確保上述結果中都能爲支持中文的字符集,能夠看出,個人電腦中character_set_database和 character_set_server仍然是latin1.在mysql5.1版本中,修改my.cnf文件,在其中的mysqld]和 [client]下分別添加: default-character-set = utf8,在查看就應該成功。可是在mysql5.5中貌似這個文件的內容有所不一樣,依然添加default-character-set = utf8會致使mysql不能啓動,解決辦法是在my.cnf文件的[mysqld]配置選項下添加character-set-server = utf8,而後就應該能夠了。       固然也能夠不用修改my.cnf這個文件,用set name 'charsetname'命令就可使 character_set_client,character_set_connection,character_set_results都改成這個 字符集,charestname指字符集,可是重啓後又會還原。       這個總結只是針對mysql自己會出現中的亂碼問題的解決,對於java或者php連接數據庫取得結果的亂碼這個總結沒有!
相關文章
相關標籤/搜索