程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL中文問題的解決方案

MySQL中文問題的解決方案

編輯:MySQL綜合教程

以下的文章主要講述的是MySQL中文問題的實際解決方案,我們大家都知道MySQL中文問題的編碼設置與亂碼問題一直是困擾計算機人員的心病,可以說對MySQL中文問題的編碼設置與亂碼問題的解決也是迫在眉睫。

MySQL 4.1的字符集支持(Character Set Support)有兩個方面:字符集(Character set)和排序方式(Collation)。對於字符集的支持細化到四個層次: 服務器(server),數據庫(database),數據表(table)和連接(connection)。我們最終的目標是使得這四個層次轉化會支持中文的編碼,下面以utf8為例。

1. 首先查看系統的字符集和排序方式。如果想查看某個特定的數據庫的字符集和排序方式,應該先選定數據庫,MySQL>use databasename;

  1. MySQL> SHOW VARIABLES LIKE ''character_set_%'';   
  2. +--------------------------+----------------------------+   
  3. | Variable_name | Value |   
  4. +--------------------------+----------------------------+   
  5. | character_set_client | latin1 |   
  6. | character_set_connection | latin1 |   
  7. | character_set_database | latin1 |   
  8. | character_set_results | latin1 |   
  9. | character_set_server | latin1 |   
  10. | character_set_system | utf8 |   
  11. | character_sets_dir | /usr/share/MySQL/charsets/ |   
  12. +--------------------------+----------------------------+  

2 rows in set (0.00 sec)

  1. MySQL> SHOW VARIABLES LIKE ''collation_%'';   
  2. +----------------------+-------------------+   
  3. | Variable_name | Value |   
  4. +----------------------+-------------------+   
  5. | collation_connection | latin1_swedish_ci |   
  6. | collation_database | latin1_swedish_ci |   
  7. | collation_server | latin1_swedish_ci |   
  8. +----------------------+-------------------+  

3 rows in set (0.00 sec) 上面列出的值就是系統的默認值,lanti是不支持中文的,所以我們把它改成urf8。

下面我們就來修改這四個層次的編碼方式:

1 在my.cf文件的[MySQL中文問題]段設置:

  1. default-character-set=utf8  

這條語句的作用是把character_set_client, character_set_connection_,character_set_results 設定為utf8,包括對應的排列方式的編碼。 Character_set_server是系統編碼,這個是不用改的。

當然改變character_set_client, character_set_connection_,character_set_results編碼方式的另外一種方法是:

  1. SET NAMES “UTF8”;  

它的作用相當於:

  1. SET character_set_client = utf8;   
  2. SET character_set_results = utf8;   
  3. SET character_set_connection = utf8;  

2. 改變數據庫的編碼方式

  1. alter database databasename character set utf8;  

通過以上的更改數據庫的編碼工作算是昨晚了,當然除了這個方法還有一個萬能個的方法,那就是看著那個不是utf8,你只要把相應的編碼改成utf8就可以了。格式如下:SET

  1. character_set_client = utf8;  

3. 不管你是web編程還是桌面編程,你的數據庫的連接地址url中,一定要後綴:

?useUnicode=true&characterEncoding=utf-8/hibernate?useUnicode=true&characterEncoding=utf-8

當然如果你采用了MySQL中文問題的管理工具如MySQL yog,MySQL manager那麼你數據庫設定也可以在可視化環境下直接設置。當然這也只是限制在database的設定。

編輯推薦】

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved