查看MySQL編碼
創(chuàng)新互聯(lián)建站是一家專業(yè)提供蚌山企業(yè)網(wǎng)站建設,專注與成都網(wǎng)站建設、做網(wǎng)站、H5技術、小程序制作等業(yè)務。10年已為蚌山眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設計公司優(yōu)惠進行中。
SHOW VARIABLES LIKE 'char%';
因為當初安裝時指定了字符集為UTF8,所以所有的編碼都是UTF8。
?character_set_client:你發(fā)送的數(shù)據(jù)必須與client指定的編碼一致?。。》掌鲿褂迷摼幋a來解讀客戶端發(fā)送過來的數(shù)據(jù);
?character_set_connection:通過該編碼與client一致!該編碼不會導致亂碼!當執(zhí)行的是查詢語句時,客戶端發(fā)送過來的數(shù)據(jù)會先轉換成connection指定的編碼。但只要客戶端發(fā)送過來的數(shù)據(jù)與client指定的編碼一致,那么轉換就不會出現(xiàn)問題;
?character_set_database:數(shù)據(jù)庫默認編碼,在創(chuàng)建數(shù)據(jù)庫時,如果沒有指定編碼,那么默認使用database編碼;
?character_set_server:MySQL服務器默認編碼;
?character_set_results:響應的編碼,即查詢結果返回給客戶端的編碼。這說明客戶端必須使用result指定的編碼來解碼;
控制臺編碼
修改character_set_client、character_set_results、character_set_connection為GBK,就不會出現(xiàn)亂碼了。但其實只需要修改character_set_client和character_set_results。
控制臺的編碼只能是GBK,而不能修改為UTF8,這就出現(xiàn)一個問題??蛻舳税l(fā)送的數(shù)據(jù)是GBK,而character_set_client為UTF8,這就說明客戶端數(shù)據(jù)到了服務器端后一定會出現(xiàn)亂碼。既然不能修改控制臺的編碼,那么只能修改character_set_client為GBK了。
服務器發(fā)送給客戶端的數(shù)據(jù)編碼為character_set_result,它如果是UTF8,那么控制臺使用GBK解碼也一定會出現(xiàn)亂碼。因為無法修改控制臺編碼,所以只能把character_set_result修改為GBK。
?修改character_set_client變量:set character_set_client=gbk;
?修改character_set_results變量:set character_set_results=gbk;
設置編碼只對當前連接有效,這說明每次登錄MySQL提示符后都要去修改這兩個編碼,但可以通過修改配置文件來處理這一問題:配置文件路徑:D:\Program Files\MySQL\MySQL Server 5.1\ my.ini
1、查看數(shù)據(jù)庫編碼格式
mysql?show?variables?like?'character_set_database'
2、查看數(shù)據(jù)表的編碼格式
mysql?show?create?table?表名;
3、創(chuàng)建數(shù)據(jù)庫時指定數(shù)據(jù)庫的字符集
mysqlcreate?database?數(shù)據(jù)庫名?character?set?utf8;
4、創(chuàng)建數(shù)據(jù)表時指定數(shù)據(jù)表的編碼格式
create?table?tb_books?(
name?varchar(45)?not?null,
price?double?not?null,
bookCount?int?not?null,
author?varchar(45)?not?null?)?default?charset?=?utf8;
5、修改數(shù)據(jù)庫的編碼格式
mysqlalter?database?數(shù)據(jù)庫名?character?set?utf8;
6、修改數(shù)據(jù)表格編碼格式
mysqlalter?table?表名?character?set?utf8;
7、修改字段編碼格式
mysqlalter?table?表名?change?字段名?字段名?類型?character?set?utf8;
mysqlalter?table?user?change?username?username?varchar(20)?character?set?utf8?not?null;
基本上現(xiàn)在的字符集 MySQL 都支持,查看 MySQL 支持的字符集列表, 有兩種方法:
1. SQL 語句
2. 查看元數(shù)據(jù)字典表
查詢結果:
1)第一列代表字符集名字;
2)第二列表示字符集排序規(guī)則;
3)第三列表示字符集描述;
4)第四列表示字符集編碼的最大字節(jié)數(shù)。
MySQL中,數(shù)據(jù)庫的編碼是一個相當重要的問題,有時候我們需要查看一下當前數(shù)據(jù)庫的編碼,甚至需要修改一下數(shù)據(jù)庫編碼。
查看當前數(shù)據(jù)庫編碼的SQL語句為:
mysql use xxx
Database changed
mysql show variables like
'character_set_database';
+------------------------+--------+
|
Variable_name | Value |
+------------------------+--------+
|
character_set_database | latin1 |
+------------------------+--------+
1
row in set (0.00 sec)
上面,我們先切換到xxx數(shù)據(jù)庫下面來,然后使用SQL語句:show variables like 'character_set_database';
來查看了xxx數(shù)據(jù)庫的編碼。查詢得到的結果是latin1編碼。
下面,我們來修改xxx數(shù)據(jù)庫的編碼,把它修改為gb2312。
mysql alter database xxx CHARACTER SET
gb2312;
Query OK, 1 row affected (0.00 sec)
mysql show variables like
'character_set_database';
+------------------------+--------+
|
Variable_name | Value |
+------------------------+--------+
|
character_set_database | gb2312 |
+------------------------+--------+
1
row in set (0.00 sec)
打開mysql命令端,輸入登錄密碼進行驗證
驗證成功,輸入 show create database day15; 點擊回車(day15為數(shù)據(jù)庫名稱)
在下方的信息欄即可看到當前查詢數(shù)據(jù)庫編碼信息。
如果需要修改編碼信息,可以輸入alter database day15 default character set gbk;點擊回車即可
MySQL的默認編碼是Latin1,不支持中文,要支持中午需要把數(shù)據(jù)庫的默認編碼修改為gbk或者utf8。
需要以root用戶身份登陸才可以查看數(shù)據(jù)庫編碼方式(以root用戶身份登陸的命令為:mysql -u root –p,之后兩次輸入root用戶的密碼),查看數(shù)據(jù)庫的編碼方式命令為:
show variables like 'character%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
從以上信息可知數(shù)據(jù)庫的編碼為latin1,需要修改為gbk或者是utf8;
其中,character_set_client為客戶端編碼方式;character_set_connection為建立連接使用的編碼;character_set_database數(shù)據(jù)庫的編碼;
character_set_results結果集的編碼;
character_set_server數(shù)據(jù)庫服務器的編碼;
只要保證以上四個采用的編碼方式一樣,就不會出現(xiàn)亂碼問題。
另一個查看數(shù)據(jù)庫編碼的命令:
show variables like ‘collation%’;