資源描述:
《mysql中文亂碼問(wèn)題完美解決方案》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫(kù)。
1、轉(zhuǎn)載:Mysql中文亂碼的解決方法第一種方法,很精辟的總結(jié):經(jīng)常更換虛擬主機(jī),而各個(gè)服務(wù)商的MYSQL版本不同,當(dāng)導(dǎo)入數(shù)據(jù)后,總會(huì)出現(xiàn)亂碼等無(wú)法正常顯示的問(wèn)題,查了好多資料,總結(jié)出自己的一點(diǎn)技巧:WINDOWS下導(dǎo)入應(yīng)該這樣使用MYSQL的命令在DOS命令下進(jìn)入mysql的bin目錄下,輸入mysql-uroot-p密碼數(shù)據(jù)庫(kù)名稱(chēng)<要恢復(fù)的數(shù)據(jù)庫(kù),例如我們要把D盤(pán)的一個(gè)名稱(chēng)為test.sql的數(shù)據(jù)庫(kù)恢復(fù)到本地的test2這個(gè)數(shù)據(jù)庫(kù),那么就這樣:mysql-uroot-p密碼test2以前的國(guó)外主機(jī)用的Mysql是4.x系列的,感覺(jué)還比較好,都無(wú)論GBK和UTF-8都沒(méi)有亂碼
2、,沒(méi)想到新的主機(jī)的Mysql是5.0版本的,導(dǎo)入數(shù)據(jù)后,用Php讀出來(lái)全是問(wèn)號(hào),亂碼一片,記得我以前也曾經(jīng)有過(guò)一次切換出現(xiàn)亂碼的經(jīng)驗(yàn),原因肯定是Mysql版本之間的差異問(wèn)題。只好查資料,發(fā)現(xiàn)了一個(gè)解決方法,就是在mysql_connect后面加一句SETNAMESUTF8,即可使得UTF8的數(shù)據(jù)庫(kù)消除亂碼,對(duì)于GBK的數(shù)據(jù)庫(kù)則使用SETNAMESGBK,代碼如下:$mysql_mylink=mysql_connect($mysql_host,$mysql_user,$mysql_pass);mysql_query("SETNAMES'GBK'");?數(shù)據(jù)庫(kù)字符集為utf-8
3、連接語(yǔ)句用這個(gè)mysql_query("SETNAMES'UTF8'");mysql_query("SETCHARACTERSETUTF8");mysql_query("SETCHARACTER_SET_RESULTS=UTF8'");還有個(gè)方法就是,如果你自己的機(jī)器的話,可以更改MYSQL字符集,一般在MYSQ4和MYSQL5這兩個(gè)版本中有效。第二個(gè)方法:很不錯(cuò)的解說(shuō),可以試一下mysql亂碼處理總結(jié):??????(1)java中處理中文字符正常,在cmdclient中顯示亂碼是字符集的問(wèn)題.??????(2)字段長(zhǎng)度設(shè)置夠長(zhǎng),但插入中文字符時(shí)提示com.mysql.jd
4、bc.MysqlDataTruncation:Datatruncation:Datatoolongforcolumn錯(cuò)誤是字符集的問(wèn)題.??????(3)亂碼問(wèn)題歸根到底是字符集的問(wèn)題,那就從字符集設(shè)置方面考慮,不外乎下面幾個(gè)方面:server,client,database,connection,results.-------------------------解決辦法----------------------(1)修改my.ini(MySQLServerInstanceConfiguration文件)#CLIENTSECTION//客戶端[client]port=33
5、06[mysql]default-character-set=gbk#SERVERSECTION??//服務(wù)端[mysqld]default-character-set=gbk(2)修改data目錄中相應(yīng)數(shù)據(jù)庫(kù)目錄下的db.opt配置文件default-character-set=gbkdefault-collation=gbk_chinese_ci(3)數(shù)據(jù)庫(kù)連接串中指定字符集URL=jdbc:mysql://yourIP/college?user=root&password=yourPassword&useUnicode=true&characterEncoding=g
6、bk注:在mysql4.1.0版要加useUnicode=true&characterEncoding=gbk如果是5.0版以上的,加不加都是沒(méi)有關(guān)系的!(4)在創(chuàng)建數(shù)據(jù)庫(kù)時(shí)指定字符集createdatabaseyourDBCHARACTERSETgbk;(5)在dos命令上要設(shè)置setnamesgbk??????好了,經(jīng)過(guò)檢查上面四個(gè)方面的設(shè)置,應(yīng)該OK了!不會(huì)出現(xiàn)諸如com.mysql.jdbc.MysqlDataTruncation:Datatruncation:Datatoolongforcolumn等問(wèn)題.第三種方法,說(shuō)有太復(fù)雜了,反到不知道怎么弄了,你試試,也許
7、可以用得上1.修改/etc/my.cnf文件,改成這樣:[mysqld]datadir=/var/lib/mysqlsocket=/var/lib/mysql/mysql.sockdefault-character-set=utf8[mysql.server]user=mysqlbasedir=/var/lib[mysqld_safe]err-log=/var/log/mysqld.logpid-file=/var/run/mysqld/mysqld.pid注意:就是加入了一句default-character-s