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

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

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

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

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

解決済

MySQL(MariaDB)での日本語の文字化けを解消したい

shibuchaaaan
shibuchaaaan

総合スコア0

MySQL

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

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。

5回答

1評価

3クリップ

10253閲覧

投稿2019/04/09 07:31

編集2022/01/12 10:58

前提・実現したいこと

MySQL(MariaDB)での日本語の文字化けを解消したいです。
ネットに載っている解決法を色々試しましたが、お手上げ状態なのでこの環境での解決策をご教示いただけると助かります。

###環境
Windows10
XAMPP 7.2.6
MySQL Ver 15.1 Distrib 10.1.33-MariaDB, for Win32
※SQL文はコマンドプロンプトで打ち込んでいます

発生している問題・エラーメッセージ

コマンドプロンプトからSQL文でINSERTすると日本語のみ文字化けする。

command

MariaDB [testdb]> insert into test(name,skill)values('みき','HTML'); MariaDB [testdb]> select* from test; +----+------+-------+ | id | name | skill | +----+------+-------+ | 1 | ・ン・ォ | HTML | +----+------+-------+

試したこと

①まずはDBの文字コード設定を確認。

command

MariaDB [testdb]> show variables like "chara%"; +--------------------------+--------------------------------+ | Variable_name | Value | +--------------------------+--------------------------------+ | character_set_client | cp932 | | character_set_connection | cp932 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | cp932 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | C:\xampp\mysql\share\charsets\ | +--------------------------+--------------------------------+

DBの設定

command

MariaDB [testdb]> show create database testdb; +----------+-----------------------------------------------------------------+ | Database | Create Database | +----------+-----------------------------------------------------------------+ | testdb | CREATE DATABASE `testdb` /*!40100 DEFAULT CHARACTER SET utf8 */ | +----------+-----------------------------------------------------------------+

テーブルの設定

command

MariaDB [testdb]> desc test; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | MUL | NULL | auto_increment | | name | varchar(20) | YES | | NULL | | | skill | varchar(20) | YES | | NULL | | +-------+-------------+------+-----+---------+----------------+

https://qiita.com/YusukeHigaki/items/2cab311d2a559a543e3aを参考に、my.iniの[client]と[mysqld]の文字コードをutf8に書き換え。
DBの設定を確認しましたが、文字コードの設定が最初と変わっていなかったので、

③my.ini[mysql]のdefault-set-characterもutf8に書き換え。

DBの設定

command

MariaDB [(none)]> show variables like "chara%"; +--------------------------+--------------------------------+ | 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 | C:\xampp\mysql\share\charsets\ | +--------------------------+--------------------------------+

この状態で新たにDB作成し、INSERT

command

MariaDB [(none)]> create database test2; MariaDB [test2]> create table table1(id int auto_increment,name varchar(20),skill varchar(20),index(id)); MariaDB [test2]> insert into table1(name,skill)values('みき','PHP'); MariaDB [test2]> select* from table1; +----+------+-------+ | id | name | skill | +----+------+-------+ | 1 | ?ン・? | PHP | +----+------+-------+

これでもダメだったので、
https://teratail.com/questions/26559を参考に、
my.iniの[mysql]default-character-setをcp932に書き換え。

DB設定

command

MariaDB [(none)]> show variables like "chara%"; +--------------------------+--------------------------------+ | Variable_name | Value | +--------------------------+--------------------------------+ | character_set_client | cp932 | | character_set_connection | cp932 | | character_set_database | utf8 | | character_set_filesystem | binary | | character_set_results | cp932 | | character_set_server | utf8 | | character_set_system | utf8 | | character_sets_dir | C:\xampp\mysql\share\charsets\ | +--------------------------+--------------------------------+

設定が元通りなので意味ないと思うが、この状態で再度DB作成してINSERT

command

MariaDB [(none)]> create database test3; MariaDB [test3]> create table table3(id int,name varchar(20),skill varchar(20)); MariaDB [test3]> insert into table3(id,name,skill)values(1,'みき','CSS'); MariaDB [test3]> select* from table3; +------+------+-------+ | id | name | skill | +------+------+-------+ | 1 | ・ン・ォ | CSS | +------+------+-------+

https://teratail.com/questions/58424を参考にset namesしてみた

command

MariaDB [(none)]> set names cp932; MariaDB [(none)]> create database newone; MariaDB [newone]> create table tbl3(id int,name varchar(10),skill varchar(10)); MariaDB [newone]> insert into tbl3(id,name,skill)values(1,'みき','HTML'); MariaDB [newone]> select* from tbl3; +------+------+-------+ | id | name | skill | +------+------+-------+ | 1 | ・ン・ォ | HTML | +------+------+-------+

これでもダメだったので、もうお手上げ状態です…。
どこをどう変えたらよいのでしょうか…

###整理
状況を整理すると、

  • DBの文字設定全てutf9にしても直らない
  • 文字設定の中で[character_set_client],[character_set_connection],[character_set_results]がcp932でも直らない

ということになっています。
ご教示いただけると幸いです。

参考にしたURL

https://teratail.com/questions/135821
https://teratail.com/questions/124308

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

FKM
FKM

2019/04/09 07:39

質問を2点 1、どんな感じで文字化けしていますか。日本語が????になる、など 2、プログラムは何を使ってデータを呼び出そうとしていますか?
shibuchaaaan
shibuchaaaan

2019/04/10 01:04

1.日本語が「 ・ノ・・」「 ・・・B・E・ォ・・」のようになります。 2.データの呼び出し・挿入は全てコマンドプロンプト上で行っています。
FKM
FKM

2019/04/10 01:54

そもそも、コマンドプロンプト自体、sjisは見えているのでしょうか?
shibuchaaaan
shibuchaaaan

2019/04/10 10:22

文字コードをsjisにすると、入れた日本語は「????」となります。見えないですね…。
shibuchaaaan
shibuchaaaan

2019/04/11 03:02

なるほど…!これは知りませんでした。ありがとうございます。 コマンドプロンプトの文字コードはShift-JISだったのですが、そのままだと何も変わらなかったのでUTF8に変えたところ、ちゃんと表示されました! 鞭ですみません…。 皆様、本当にありがとうございました。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

MySQL

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

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

コマンドプロンプト

コマンドプロンプト(cmd.exe)はMicrosoftによって提供されているコマンドラインインタプリタです。OS/2・Windows CE・Windows NTで使用可能です。

MariaDB

MariaDBは、MySQL派生のオープンソースなリレーショナルデータベースシステムです。 また、MySQLとほぼ同じデータベースエンジンに対応しています。