MySQL

MySQLでデータベースとテーブルの文字コードがlatin1だったのでUTF-8にする

More than 1 year has passed since last update.

MySQL5.6 on Linuxをインストールし、設定ファイルをデフォルトの状態でデータベース作成、テーブルを作成をしたら、文字コードがlatin1になっていたものを直したときのメモ。

参考

事象

テーブルを作成したが、文字コードがlatin1だった。。。。

# テーブル作成
mysql>create table t1 ( id INT, dep INT, name CHAR(30));

# テーブル情報確認
mysql>show create table t1;
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                         |
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------+
| t1    | CREATE TABLE `t1` (
  `id` int(11) DEFAULT NULL,
  `dep` int(11) DEFAULT NULL,
  `name` char(30) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1 |
+-------+------------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

SQLで文字コードの設定を確認します。

mysql> show variables like 'character%';
+--------------------------+------------------------------+
| Variable_name            | Value                        |
+--------------------------+------------------------------+
| character_set_client     | utf8                         |
| character_set_connection | utf8                         |
| character_set_database   | latin1                       |
| character_set_filesystem | binary                       |
| character_set_results    | utf8                         |
| character_set_server     | latin1                       |
| character_set_system     | utf8                         |
| character_sets_dir       | /usr/share/mysql56/charsets/ |
+--------------------------+------------------------------+
8 rows in set (0.00 sec)

mysqlコマンドを実行しているクライアントとMySQLサーバーをインストールしているサーバーは一緒でlocaleコマンドを見るとUTF-8になっています。

クライアント側は文字コードがutf8となっていることからも分かります。
ただ、サーバー側はlocaleの状態や接続クライアントの文字コードは関係ないみたいですね。書籍を確認するとMySQLのバイナリの標準キャラクタセットがlatin1らしいので特に何も設定しないと上記のようになっているのではないないかと思われます。

修正する

SQL実行時に文字コードを指定する方法もあるようですが、面倒なので固定でUTF-8を使うようにしたいです。

上記はMySQL起動時に読み込む設定ファイルを利用すればいけるようなのでやってみます。

/etc/my.cnf
[mysqld]
...
character-set-server=utf8

上記記載後、再起動して確認します。

# mysqldプロセスの再起動
$sudo service mysqld restart

# 確認
mysql> show variables like 'character%';
+--------------------------+------------------------------+
| Variable_name            | Value                        |
+--------------------------+------------------------------+
| character_set_client     | utf8                         |
| character_set_connection | utf8                         |
| character_set_database   | utf8                         |
| character_set_filesystem | binary                       |
| character_set_results    | utf8                         |
| character_set_server     | utf8                         |
| character_set_system     | utf8                         |
| character_sets_dir       | /usr/share/mysql56/charsets/ |
+--------------------------+------------------------------+
8 rows in set (0.00 sec)

なお、確認するとテーブルだけでなくデータベースもlatin1だったのでこちらから再作成し直します。

mysql> show create database testdb;
+----------+-------------------------------------------------------------------+
| Database | Create Database                                                   |
+----------+-------------------------------------------------------------------+
| testdb   | CREATE DATABASE `testdb` /*!40100 DEFAULT CHARACTER SET latin1 */ |
+----------+-------------------------------------------------------------------+
1 row in set (0.00 sec)

再作成して確認

まず、削除

# testdbの削除
mysql>drop database testdb;

# testdbの作成
mysql> create database testdb;

# testuserでログイン
$mysql -u testuser -p testdb

# データベースの文字コード確認
mysql> show create database testdb;
+----------+-----------------------------------------------------------------+
| Database | Create Database                                                 |
+----------+-----------------------------------------------------------------+
| testdb   | CREATE DATABASE `testdb` /*!40100 DEFAULT CHARACTER SET utf8 */ |
+----------+-----------------------------------------------------------------+
1 row in set (0.00 sec)

# テーブル作成
mysql>create table t1 ( id INT, dep INT, name CHAR(30));

# テーブル情報確認
mysql>show create table t1;

# 確認
mysql> show create table t1;
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                                                                       |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------+
| t1    | CREATE TABLE `t1` (
  `id` int(11) DEFAULT NULL,
  `dep` int(11) DEFAULT NULL,
  `name` char(30) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+----------------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)

無事、データベースもテーブルもUTF-8に出来ました!