一、mysql的多字符集支持
1、設置mysqld服務同時支持多個字符集
將mysqld服務的默認字符集改爲utf8,並同時支持latin1、gbk、gb2312、big5、ascii字符集。可以爲不同的數據庫、表使用不同的字符集編碼。
Step1:./configure步驟時需增加字符集支持選項,例如:
shell> ./configure --with-charset=utf8 --with-collation=utf8_bin --with-extra-charsets=big5,ascii,gb2312,gbk,utf8,latin1
//默認的字符集缺省爲latin1。
//其中,utf8對應可用的collation值爲:utf8_bin、utf8_general_ci、utf8_unicode_ci
//extra支持也可以使用 "--with-extra-charsets=all"。
Step2:在make步驟之前,修改config.h頭文件,查找utf8、gbk、gb2312等定義字符集變量的行,確認有如下內容(如果沒有則需要手動添加),例如:
#define HAVE_CHARSET_ascii 1
#define HAVE_CHARSET_big5 1
#define HAVE_CHARSET_gb2312 1
#define HAVE_CHARSET_gbk 1
#define HAVE_CHARSET_latin1 1
#define HAVE_CHARSET_utf8 1
//一開始沒有修改config.h,費了好多功夫,"mysql>"環境中使用非默認字符集時總報"Error 1115"錯誤:
mysqld> set names gbk;
ERROR 1115 (42000): Unknown character set: 'gbk'
//後來發現在./configure完成後,config.h文件中並沒有自動打開gbk、gb2312等變量定義,不得不手動修改添加。
2、驗證mysqld服務的多字符集支持
1) 查看當前mysql數據庫支持的字符集
mysql> show character set;
2) 查看對應字符集可用的校對規則
mysql> show collation like 'gb%';
mysql> show collation like 'utf8%';
3) 查看當前mysql服務器使用的默認字符集狀態
mysql> status
……
Server characterset: utf8
Db characterset: utf8
Client characterset: utf8
Conn. characterset: utf8
4) 在創建數據庫時指定使用的默認字符集:
mysql> create database testdb default character set utf8;
mysql> show create database testdb; //驗證數據庫建立信息
5) 在創建數據表時指定使用的默認字符集:
mysql> create table testdb.tb1 ( id int(10) unsigned NOT NULL AUTO_INCREMENT,name varchar(15) NOT NULL default '',PRIMARY KEY (id) ) ENGINE=MyISAM DEFAULT CHARACTER SET gb2312;
mysql> show create table testdb.tb1; //驗證數據表建立信息
6) 在mysql>客戶端環境中設置使用的默認字符集
mysql> set NAMES utf8;