本文將為大家講解如何處理Java連接過(guò)程中的MySQL中文亂碼問(wèn)題。一般MySQL中文亂碼問(wèn)題都是與字符集有關(guān),這里作者的經(jīng)歷也大致差不多。
MySQL默認(rèn)編碼是latin1
1. mysql> show variables like 'character%';
2. +--------------------------+--------------------------+
3. | Variable_name | Value |
4. +--------------------------+--------------------------+
5. | character_set_client | latin1 |
6. | character_set_connection | latin1 |
7. | character_set_database | latin1 |
8. | character_set_filesystem | binary |
9. | character_set_results | latin1 |
10. | character_set_server | latin1 |
11. | character_set_system | utf8 |
12. | character_sets_dir | D:\MySQL\share\charsets\ |
13. +--------------------------+--------------------------+
14. 創(chuàng)建數(shù)據(jù)表并插入數(shù)據(jù)
15. mysql> use test;
16. mysql> create table messages (
17. -> id int(4) unsigned auto_increment primary key,
18. -> message varchar(50) not null
19. -> ) engine=myisam default charset=utf8;
20. mysql> insert into messages (message) values ("測(cè)試MySQL中文顯示");
21. mysql> select * from messages;
22. +----+-------------------+
23. | id | message |
24. +----+-------------------+
25. | 1 | 測(cè)試MySQL中文顯示 |
26. +----+-------------------+
27. 編寫程序(Java)
28. import java.sql.Connection;
29. import java.sql.DriverManager;
30. import java.sql.ResultSet;
31. import java.sql.Statement;
32. public class JDBCTest {
33. public static void main(String[] args) {
34. String driver = "com.mysql.jdbc.Driver";
35. String url = "jdbc:mysql://localhost:3306/test";
36. String user = "root";
37. String password = "root";
38. try {
39. Class.forName(driver);
40. Connection conn = DriverManager.getConnection(url, user, password);
41. Statement stmt = conn.createStatement();
42. stmt.executeUpdate("insert into messages (message) values ('測(cè)試MySQL編碼')");
43. ResultSet rs = stmt.executeQuery("select * from messages");
44. while (rs.next()) {
45. int id = rs.getInt("id");
46. String message = rs.getString("message");
47. System.out.println(id + " " + message);
48. }
49. rs.close();
50. stmt.close();
51. conn.close();
52. } catch (Exception e) {
53. e.printStackTrace();
54. }
55. }
56. }
57. 程序輸出
58. 1 ????MySQL????????
59. 2 ??MySQL??
我們看到,盡管使用數(shù)據(jù)庫(kù)時(shí)我們能夠正常的添加和顯示中文,但是在使用程序連接數(shù)據(jù)庫(kù)時(shí)并不能夠正常顯示中文,為此我們需要修改MySQL的默認(rèn)編碼,編輯my.ini(MySQL配置文件)文件對(duì)編碼進(jìn)行修改
設(shè)置MySQL的默認(rèn)字符集為utf8,找到客戶端配置[client]在下面添加。
default-character-set=utf8
找到服務(wù)器配置[mysqld]在下面添加
default-character-set=utf8
設(shè)定MySQL數(shù)據(jù)庫(kù)以u(píng)tf8編碼運(yùn)行,連接MySQL數(shù)據(jù)庫(kù)時(shí)使用utf8編碼
停止和重新啟動(dòng)MySQL
net stop mysql
net start mysql
//實(shí)際中,最新mySQL以上兩句已經(jīng)失效,在命令行中先exit 然后重新登錄可以實(shí)現(xiàn)這個(gè)目的
重新連接數(shù)據(jù)庫(kù),查看編碼,數(shù)據(jù)表內(nèi)容
???????? 1. mysql> show variables like 'character%';?
???????? 2. +--------------------------+--------------------------+?
???????? 3. | Variable_name??????????? | Value??????????????????? |?
???????? 4. +--------------------------+--------------------------+?
???????? 5. | character_set_client???? | utf8???????????????????? |?
???????? 6. | character_set_connection | utf8???????????????????? |?
???????? 7. | character_set_database?? | utf8???????????????????? |?
???????? 8. | character_set_filesystem | binary?????????????????? |?
???????? 9. | character_set_results??? | utf8???????????????????? |?
??????? 10. | character_set_server???? | utf8???????????????????? |?
??????? 11. | character_set_system???? | utf8???????????????????? |????//該行未更改,建議使用替換,這樣能改的全面
??????? 12. | character_sets_dir?????? | D:\MySQL\share\charsets\ |?
??????? 13. +--------------------------+--------------------------+?
??????? 14. mysql> use test;?
??????? 15. mysql> select * from messages;?
??????? 16. +----+-------------------------------+?
??????? 17. | id | message?????????????????????? |?
??????? 18. +----+-------------------------------+?
??????? 19. |? 1 | 虜芒脢脭MySQL脰脨脦脛脧脭脢戮???????????? |?
??????? 20. |? 2 | ??MySQL?????????????????????? |?
??????? 21. +----+-------------------------------+?
??????? 22. 這里顯示依然是亂碼主要是因?yàn)橹笆褂玫木幋a不同造成的,重新運(yùn)行之前寫的程序:java JDBCTest?
??????? 23. 1 ????MySQL?????????
??????? 24. 2 ??MySQL???
??????? 25. 3 測(cè)試MySQL編碼?
??????? 26. 從第三條記錄我們可以看到現(xiàn)在程序連接數(shù)據(jù)庫(kù)時(shí)可以正常的添加和顯示中文了?//如果從MySQL command line中仍然查詢不到數(shù)據(jù),顯示數(shù)據(jù)集為空,繼續(xù)完成第三步使得系統(tǒng)的編碼和mySQL的編碼一致就可以查詢出來(lái)了……&
??????? 27. mysql> select * from messages;?
??????? 28. +----+-------------------------------+?
??????? 29. | id | message?????????????????????? |?
??????? 30. +----+-------------------------------+?
??????? 31. |? 1 | 虜芒脢脭MySQL脰脨脦脛脧脭脢戮???????????? |?
??????? 32. |? 2 | ??MySQL?????????????????????? |?
??????? 33. |? 3 | 嫻嬭瘯MySQL緙栫爜???????????????? |?
??????? 34. +----+-------------------------------+
????? 看回?cái)?shù)據(jù)庫(kù)的顯示,我們會(huì)很奇怪的發(fā)現(xiàn)為什么顯示的都是亂碼,這主要是和windows下命令行的編碼有關(guān),在命令行上(命令提示符左上角圖標(biāo)處右鍵屬 性)查看屬性->選項(xiàng)的當(dāng)前代碼頁(yè):936?? (ANSI/OEM - 簡(jiǎn)體中文 GBK)(本人機(jī)子上是這樣顯示的)
????? 也就是說(shuō)命令行上使用的是GBK編碼,而我們是在程序連接時(shí)使用utf8進(jìn)行添加的,所以會(huì)出現(xiàn)有亂碼,現(xiàn)在我們將客戶端的編碼改成gb2312或gbk試一下
???????? 1. mysql> show variables like 'character%';?
???????? 2. +--------------------------+--------------------------+?
???????? 3. | Variable_name??????????? | Value??????????????????? |?
???????? 4. +--------------------------+--------------------------+?
???????? 5. | character_set_client???? | gb2312?????????????????? |?
???????? 6. | character_set_connection | gb2312?????????????????? |?
???????? 7. | character_set_database?? | utf8???????????????????? |?
???????? 8. | character_set_filesystem | binary?????????????????? |?
???????? 9. | character_set_results??? | gb2312?????????????????? |?
??????? 10. | character_set_server???? | utf8???????????????????? |?//最后你會(huì)發(fā)現(xiàn)這個(gè)還是沒(méi)有更改,見下文
??????? 11. | character_set_system???? | utf8???????????????????? |?
??????? 12. | character_sets_dir?????? | D:\MySQL\share\charsets\ |?
??????? 13. +--------------------------+--------------------------+?
??????? 14. mysql> use test;?
??????? 15. mysql> select * from messages;?
??????? 16. +----+-------------------+?
??????? 17. | id | message?????????? |?
??????? 18. +----+-------------------+?
??????? 19. |? 1 | ????MySQL???????? |?
??????? 20. |? 2 | ??MySQL?????????? |?
??????? 21. |? 3 | 測(cè)試MySQL編碼???? |?
??????? 22. +----+-------------------+
????? 補(bǔ)充:更改character_set_server,在安裝目錄的bin文件夾下使用MySQLInstanceConfig.exe配置,在很多步驟中的一步(選擇編碼)選擇第二項(xiàng)(使用UTF-8)或者第三項(xiàng)(自己設(shè)定)……更改完畢……
現(xiàn)在可以看到中文正常顯示了(主要是因?yàn)閡tf8也支持中文),所以當(dāng)我們使用命令行工具連接數(shù)據(jù)庫(kù)的時(shí)候最好將客戶端的編碼改一下,如果使用GUI的話就不必了,同時(shí)修改客戶端的編碼之后程序依然能夠正常顯示(以上兩點(diǎn)已經(jīng)測(cè)試)
????? 所以如果在程序中要顯示中文的話我們可以選用utf8,gb2312,gbk這三種編碼,但是如果想在命令行添加中文數(shù)據(jù)或者查看的話就需要將客戶端的編碼設(shè)置為gb2312或gbk了,還是那句,CMD的編碼有關(guān)
?
迷茫啊!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
1.查詢編碼
show variables like ' character% ' ;
2.設(shè)置數(shù)據(jù)庫(kù)字符集
alter database moviesite character set utf8
3.設(shè)置表的字符集
alter table movie convert to character set utf8
4.不知道
set character_set_results = utf8
5.不知道
set character set utf8
6.不知道
set names ' utf8 '
?
有時(shí)候這些都不管用,要設(shè)置成gbk或gb2312,好像沒(méi)什么規(guī)律,我擦!。
?
php網(wǎng)頁(yè)出現(xiàn)亂碼一般是在建立數(shù)據(jù)庫(kù)時(shí)用的編碼和php網(wǎng)頁(yè)的編碼不同造成的,?
用phpmyadmin建立的數(shù)據(jù)庫(kù)如果你不指定編碼他默認(rèn)是latin1_swedish_ci 編碼,既瑞典語(yǔ)不區(qū)分大小寫,而我們中國(guó)做的網(wǎng)頁(yè)不是GBK就是GB2312編碼,這樣不出現(xiàn)亂碼才怪.?
1,建立數(shù)據(jù)庫(kù)時(shí)指定編碼.?
在此再嘮叨一下常用的編碼,免的新手又迷茫:?
如果你做的是簡(jiǎn)體中文網(wǎng)頁(yè),那么你在建立數(shù)據(jù)庫(kù)時(shí)用GB2312編碼,gb2312_chinese_ci.?
如果你做的是繁體中文網(wǎng)頁(yè),那么你建立數(shù)據(jù)庫(kù)時(shí)要用gib5編碼, big5_chinese_ci?
如果你做的網(wǎng)頁(yè)有簡(jiǎn)體也有繁體中文,那么推薦你用GBK編碼,gbk_chinese_ci . GBK包含的字碼比GB2312要多,當(dāng)然繁體也在其中.?
如果你做的是多國(guó)語(yǔ)言網(wǎng)頁(yè),那么推薦你用UTF-8編碼 . mysql中有二種utf8編碼可供選擇 : utf8_unicode_ci與utf8_general_ci 筆者一般用utf8_general_ci ,關(guān)于這二種編碼的區(qū)別,請(qǐng)參考本站的另一篇文章: Mysql中校對(duì)集utf8_unicode_ci與utf8_general_ci的區(qū)別?
我們用UTF-8編碼為例建立數(shù)據(jù)庫(kù)如圖:?
?
?
2,用php連接數(shù)據(jù)庫(kù)時(shí)用mysq_query 設(shè)定一下編碼?
語(yǔ)法: mysql_query("SET NAMES 'utf8'");?
例如:?
mysql_query("set names 'utf8'",$conn); //解決亂碼?
mysql_select_db('test1',$conn);?
一般情況下只要你做好了這二步,你的程序是不會(huì)出現(xiàn)亂碼的?
二般情況:
?
二般情況一般出現(xiàn)的不多,多出現(xiàn)在做的程序語(yǔ)言比較多,比如有時(shí)做utf8的,有時(shí)做gb2312的,有時(shí)又要做big5的網(wǎng)頁(yè),用IDE建立的.php文件編碼和程序要顯示的編碼不同而引起的.?
比如,我上次做了個(gè)gb2312的簡(jiǎn)體中文網(wǎng)頁(yè),現(xiàn)在老板又有吩咐要做個(gè)gbi5網(wǎng)頁(yè),但我的ide用的卻是gb2312的編碼?
就拿我常用的IDE Dreamweaver來(lái)說(shuō)吧?
?
ide新建的網(wǎng)頁(yè)是gb2312,而我卻把建好的網(wǎng)頁(yè)改成big5的了,這樣怎么會(huì)不出現(xiàn)亂碼呢,解決的方法很簡(jiǎn)單,重新另存為一下,指定一下編碼就OK了,?
如果還搞不定,那么在網(wǎng)頁(yè)頭部加一行http頭信息?
header("Content-Type:text/html;charset=utf-8");?
注意:在發(fā)送header頭信息時(shí)header前面不可以有任何輸出,包括空格在內(nèi).?
好了寫了這么多,快看看你的程序?qū)儆谀膫€(gè)情況引起的亂碼吧.
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
