いつも通り
$ mysqldump -u hoge -p hogedb > hogedb.sql
してからDBをいじって、間違えたので
$ mysql -u hoge -p hogedb < hogedb.sql
してロールバックだぜ!と思ったら、文字化けしてしまいました。
今回はDBがUJIS(EUC-JP)でしたが、my.cnfでも
[mysqld]
skip-character-set-client-handshake
default-character-set=ujis
character-set-server=ujis
[mysql]
default-character-set=ujis
などはちゃんと書いてあります。
ダンプファイルはテキストエディタでは正常に読めます(EUC-JP)。
$ mysql -u hoge -p --default-character-set=ujis < hogedb.sql
$ mysql -u hoge -p --default-character-set=binary < hogedb.sql
などを試しても結果は同じです。
何かおかしいと思ってダンプファイルをよく見たら・・・
まあ、そりゃあ、引数で何しようとSQL本体でSET NAMES utf8;
したら意味ないですよね。
my.cnfで、[mysqldump]
を設定するか、mysqldump時に引数を与えるのを忘れないようにしましょう。
今回はダンプ後だったので、エディタでこの行を消したら無事インポートできました。