整整弄了一天,終於解決了jdbc(mysql-connector-java-5.0.30)和mysq通訊中文亂碼的問題!我的系統是 linux(Ubuntu)。在java中(Myeclipse環境)使用hibernate串連mysql。儲存英文沒問題,寫(insert into)和讀(select)都能正確顯示,但是若其中帶有中文字元就成亂碼了。到網上尋找了半天資料,最後終於成功。
我的解決方案是,在/etc/my.cnf檔案中加上以下兩行內容:
[client]
default-character-set=utf8
[mysqld]
default-character-set=utf8
注意,這個檔案不一定存在,需將 /安裝原檔案/support-files/my-medium.cnf 複製到/etc/下,重新命名
需重啟mysql
停用:sudo /usr/local/mysql/bin/mysqladmin shutdown
啟用sudo /usr/local/mysql/bin/mysqld_safe -user=mysql &
查看mysql編碼
啟用後sudo /usr/local/mysql/bin/mysql
mysql>show variables like 'character%';
+--------------------------+----------------------------+
| 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 | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
注意,這樣改變後原先所建資料庫似乎不能用(不確定),盡量備份
建立資料庫,就不會有亂碼了。