質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

Q&A

4回答

7031閲覧

mysqlの文字化けの解決方法を教えてください。

LineLine

総合スコア32

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

phpMyAdmin

phpMyAdminはオープンソースで、PHPで書かれたウェブベースのMySQL管理ツールのことです。

0グッド

1クリップ

投稿2016/09/29 04:47

編集2016/10/03 06:59

CMSが実装されたサーバーをリプレースしています。
環境は以下です。
移行元サーバー:Apache/1.3.39 PHP/4.4.7
DB:mysql Ver 14.7

移行先サーバー:Apache/2.4.6 (CentOS) PHP/5.4.16
DB:mysql Ver 15.1

その際に移行元のDBが文字化けているのを発見しました。
おそらく照合順序とcharactersetが原因かと思います。

照合順序:latin1_swedish_ci

Server characterset: latin1
Db characterset: latin1
Client characterset: latin1
Conn. characterset: latin1

しかしCMSの管理画面の情報は文字化けしていないのでどこかで正しく解釈されているとは思うのですが、DBをエクスポートするとsqlファイルが文字化けて、移行先サーバーでは正しく扱われません。

文字化けを解消しつつ正しくエクスポートするにはどうしたらよいでしょう?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

mysqlの文字コードは確認する場所が多いので大変かと思いますが、
デフォルトのまま使われているのであれば下記のサイトなどを
参照して今、一度、文字コードを設定しなおされてはいかがでしょうか?

mysqlで文字コードをutf8にセットする。
http://qiita.com/YusukeHigaki/items/2cab311d2a559a543e3a

ご参考まで

投稿2016/10/04 04:27

Yatsurugi

総合スコア1628

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

エクポートする際に文字コードを指定してはどうでしょうか。
--default-character-set=utf8 の部分です。

sql

1mysqldump --default-character-set=utf8 -u root -p database_name > dump.sql

投稿2016/10/01 08:54

編集2016/10/01 08:56
04Rhadamanthus

総合スコア15

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

LineLine

2016/10/03 06:53

mysqldump --default-character-set=utf8 -u ユーザー名 -p データベース名 > dump.sql; 上記コマンドを使いましたら下記のエラーがでました。 ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near 'mysqldump --default-character-set=utf8 -u ユーザー名 -p DB名 > dump.sql' at line 1 構文の間違いらしいのですが、何か足りなかったでしょうか?
04Rhadamanthus

2016/10/03 14:18 編集

ユーザー名と -pの間が全角になっているのが原因と思われます。 下記はどうでしょうか? mysqldump --default-character-set=utf8 -u root -p sample-db > dump.sql; どうしてもダメな場合は下記サイトを参考にしてはどうでしょうか。 http://bashalog.c-brains.jp/07/06/26-184612.php
guest

0

  • MySQL

/etc/my.cnf の設定は引き継いでいますか?
MySQLで文字化けしたときの対処法 - Qiita
にあるように,character-setに関連するパラメータで文字コードの設定ができます.

  • PHP/Apache

php

1phpinfo();

でphp.iniの場所を確認して,default_charasetを設定して下さい.
PHPにおける文字化けを解決 【PHPの設定編】 | CODE COPILOT

投稿2016/09/29 05:11

KenTerada

総合スコア751

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

LineLine

2016/10/03 06:56

すみません。言葉が足りませんでした。 移行元の段階から文字化けをおこしており、しかしCSMでは正しい日本語として解釈せれているので、移行元から文字化けを起こさないようにエクスポートできたらと考えています。
guest

0

こんにちは。

おそらく、MySQLのデフォルトの文字コードのままなのだと思います。
MySQLの設定ファイルと、作成したDBやテーブルの文字コードを確認し、直せばよいかと思われます。

こちらが参考になるかと

投稿2016/09/29 05:04

CyberMergina

総合スコア295

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

LineLine

2016/09/29 05:13

ただ他のDBも同居しており、それらは照合順序がutf8_general_ciで文字化けを起こしていません。そうった環境下でmysqlの文字コードを変更しても他の正常に見れているDBに影響はないのでしょうか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問