猫型iPS細胞研究所

Windows、Linux、iOS、DB、Network

DataBase MySQL

MySQLの文字コードを変更する

投稿日:

日本語を扱うにはutf8にするべきでしょう。
アプリケーション側で接続する際に文字コードを指定することもできます。

string constr = "userid=root;password=pass;database=test;Host=localhostCharset='utf8';
MySqlConnection con = new MySqlConnection(constr);
conn.Open();

しかし複数アプリからの接続がある場合は、それぞれで指定しなくてはいけません。
やはりサーバー側で文字コードの設定をしたいものです。

まずは現状の文字コードを確認します。

show global variables like '%character%'

'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/'

次にmy.cnfにサーバー側の文字コードを設定して、MySQLを再起動します。

# vim /usr/my.cnf
[mysqld]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqldump]
default-character-set=utf8 

すると再起動時にエラーが発生しました・・・

[root@centos100 mysql]# service mysql start
Starting MySQL...The server quit without updating PID file [失敗]lib/mysql/centos100.pid).

どうやらMySQLのバージョンが上がって、
default-character-setからcharacter-set-serverに変更されたようです。
character-set-serverで設定しなおすと、MySQLも無事再起動しました。

# vim /usr/my.cnf
[mysqld]
character-set-server=utf8
[mysql]
character-set-server=utf8
[mysqldump]
character-set-server=utf8 
[root@centos100 mysql]# service mysql start
Starting MySQL.......                                      [  OK  ]

設定を確認するとutf8になっていることがわかります。
これでアプリ側で文字コードを指定しなくても日本語の登録が可能になります。

show global variables like '%character%'
'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/mysql/charsets/'

Gooleアドセンス用336

Gooleアドセンス用336

-DataBase, MySQL

執筆者:

関連記事

MySQLの実行速度テスト用PHP

1.testデータベースにtest_tableテーブルを作成。 2.1万件のデータを登録します。 3.1000件のフラグを更新 4.更新したデータを検索する時刻を測定して表示 するサンプルです。 &l …

select insert

私は以前SQLの順番にinsert selectと呼んでいて、笑われたことがあります。 select insertだ!と当時の上司に言われました。 なるほど、副問い合わせのselectが実行されて、そ …

sqlserver

SQL Server Management Studio でテーブルが変更できない

私は以前はOracleをメインで使用し、そしてここ数年間はMySQLをメインで使用しています。SQL Serverは少しかじった程度といえるでしょう。 こんな私が選択したのはSQL Server Ma …

mysql

MySQLのChar型は”(ダブルクォーテーション)ではなく'(シングルクォーテーション)でSELECT

タイトルの通り MySQLのChar型は”(ダブルクォーテーション)ではなく'(シングルクォーテーション)で囲ってSELECT しなければなりません。 正確には、そうしなければパフォーマン …

mysql

MySQLのバイナリログを見てスレーブ停止の原因を調査する

以前スレーブ側の更新がとまっていることに気付きました :x001: その時のトラブルシューティングの手順です。 INDEX1 1.スレーブ側で、SlaveS tatusを確認する2 2.スレーブ側のロ …