Linux 配置源碼安裝的MySQL同時支持多個字符集

一、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;

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章