新聞中心
字符集是一套符合和編碼,校驗規(guī)則(collation)是在字符集內(nèi)用于比較字符的一套規(guī)則,即字符集的排序規(guī)則。MySQL可以使用對種字符集和檢驗規(guī)則來組織字符。

MySQL服務(wù)器可以支持多種字符集,在同一臺服務(wù)器,同一個數(shù)據(jù)庫,甚至同一個表的不同字段都可以指定使用不同的字符集,相比oracle等其他數(shù)據(jù)庫管理系統(tǒng),在同一個數(shù)據(jù)庫只能使用相同的字符集,MySQL明顯存在更大的靈活性。
一、服務(wù)器級字符集
(1)、可以在my.cnf中設(shè)置
[mysqld]
default-character-set=gbk (5.1)
character-set-server=gbk (5.5)
(2)、可以在啟動選項中設(shè)置
mysqld --default-character-set=gbk
(3)、可以在編譯的時候設(shè)置
./configure --with-charset=gbk
或
cmake . -default-charset=gbk
如果沒有指定服務(wù)器的字符集,默認(rèn)使用latin1為服務(wù)器的字符集。
(4)、查看當(dāng)前服務(wù)器的字符集
mysql> show variables like '%char%';
+--------------------------+-----------------------------------------+
| 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/local/mysql-5.6.28/share/charsets/ |
+--------------------------+-----------------------------------------+
二、數(shù)據(jù)庫字符集
數(shù)據(jù)庫的字符集在創(chuàng)建數(shù)據(jù)庫的時候指定,也可以在創(chuàng)建完數(shù)據(jù)庫之后通過alter database語句修改。如果數(shù)據(jù)庫中已經(jīng)存在數(shù)據(jù),修改數(shù)據(jù)庫字符集并不能將已有的數(shù)據(jù)按新字符集存放。所以無法通過修改數(shù)據(jù)庫字符集修改數(shù)據(jù)的內(nèi)容。
設(shè)置數(shù)據(jù)庫字符集的規(guī)則:
(1)、如果指定了字符集和校對規(guī)則,則使用指定的規(guī)則;
(2)、如果僅指定字符集而沒有指定校對規(guī)則,則使用指定的字符集和默認(rèn)的校對規(guī)則;
(3)、如果沒有指定字符集和校對規(guī)則,則使用服務(wù)器的字符集和校對規(guī);
三、表字符集
表的字符集是在建表的時候指定的,可以通過alter table語句進(jìn)行修改。同樣,對于表中已經(jīng)存在的數(shù)據(jù),修改字符集不會影響原有的記錄,仍將使用原有的字符集。
設(shè)置表的字符集的規(guī)則同設(shè)置數(shù)據(jù)庫的字符集規(guī)則。
四、列字符集
列的字符集和校對規(guī)則可以在建表的時候指定,也可以在修改表的時候調(diào)整。(這個不常用,僅記錄一下)
五、SET NAMES命令
除了上述的四種字符集外,對實際的應(yīng)用訪問來說,還存在客戶端和服務(wù)端之間交互的字符集,如下:
(1)、character_set_client:客戶端字符集 (2)、character_set_connection:連接字符集 (3)、character_set_resluts:結(jié)果字符集
通常情況下,這3個字符集都應(yīng)該是相同的,才能保證用戶寫入的數(shù)據(jù)被正確的讀出,特別是對于中文字符。
set names命令則用于同時修改這3個參數(shù)的值。
六、關(guān)于中文字符集插入的實驗
字符集不一致是導(dǎo)致數(shù)據(jù)庫內(nèi)中文內(nèi)容亂碼的罪魁禍?zhǔn)住?/p>
實驗環(huán)境:
Server version: 5.6.28 (在此說明實驗環(huán)境是由于在學(xué)習(xí)過程中,從網(wǎng)上參考了部分資料,實驗過程與資料描述稍有出入,未查出原因,只能暫歸結(jié)為版本不同所致。)
實驗對象:
mysql> show create table char_test\G
*************************** 1. row ***************************
Table: char_test
Create Table: CREATE TABLE `char_test` (
`id` smallint(6) NOT NULL AUTO_INCREMENT,
`name` char(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=latin1
1 row in set (0.00 sec)
由上可知,char_test表的字符集是latin1,如果不設(shè)置正確的字符集,插入中文字符時,必然會出現(xiàn)如下錯誤:
mysql> insert into char_test (name) values ('小王');
ERROR 1366 (HY000): Incorrect string value: '\xE5\xB0\x8F\xE7\x8E\x8B' for column 'name' at row 1
解決方案
(1)、先set names latin1,然后再插入數(shù)據(jù)。
mysql> set names latin1;
Query OK, 0 rows affected (0.00 sec)
mysql> insert into char_test (name) values ('小王');
Query OK, 1 row affected (0.01 sec)
mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
+----+--------+
3 rows in set (0.00 sec)
(2)、在data.sql文件中指定set names latin1,然后通過source命令導(dǎo)入data.sql。
# vi data.sql
set names latin1;
insert into char_test (name) values ('小李');
mysql> source data.sql
Query OK, 1 row affected (0.00 sec)
mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
| 4 | 小李 |
+----+--------+
4 rows in set (0.00 sec)
(3)、在data.sql文件中指定set names latin1,然后通過mysql命令導(dǎo)入
# vi data.sql
set names latin1;
insert into char_test (name) values ('小張');
# mysql -uroot -p test1 # mysql -uroot -p -e "set names latin1;select * from test1.char_test;"
(4)、通過指定mysql命令的字符集參數(shù)實現(xiàn) –default-charset-set=字符集
# vi data.sql
insert into char_test (name) values ('小張');
# 錯誤方法
# mysql -uroot -p test1 Enter password: ****** ERROR 1366 (HY000) at line 1: Incorrect string value: '\xE5\xB0\x8F\xE8\xB5\xB5' for column 'name' at row 1 # 正確方法 # mysql -uroot -p --default-character-set=latin1 test1 Enter password: ****** # mysql -uroot -p -e "set names latin1;select * from test1.char_test;" Enter password: ****** +----+--------+ | id | name | +----+--------+ | 1 | Tom | | 2 | 小明 | | 3 | 小王 | | 4 | 小李 | | 5 | 小張 | | 6 | 小趙 | +----+--------+
(5)、在配置文件中指定客戶端的字符集
vi my.cnf
[client]
default-character-set=latin1
mysql> insert into char_test (name) values ('小馬');
Query OK, 1 row affected (0.00 sec)
mysql> select * from char_test;
+----+--------+
| id | name |
+----+--------+
| 1 | Tom |
| 2 | 小明 |
| 3 | 小王 |
| 4 | 小李 |
| 5 | 小張 |
| 6 | 小趙 |
| 7 | 小馬 |
+----+--------+
7 rows in set (0.00 sec)
文章名稱:詳解mysql字符集
文章轉(zhuǎn)載:http://www.dlmjj.cn/article/coepoch.html


咨詢
建站咨詢
