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

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

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

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

4回答

10074閲覧

mysqlについて、文字化けが起こっています

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2017/05/03 14:39

PHPとmysqlでログインシステムをつくっています。

番号とパスワードを入力したら、次のページでログインしている名前が出てくるというものです。

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

ログインすると下記employee_infoのテーブルの名前として入力するところがローマ字なら反映されるのですが、漢字やひらがななどを使うと、ページ遷移した時に、「??」と出てしまって文字化け(?)しています。
使用言語:php,mysql mysqlのテーブル↓ create table employee_info( id int(8) not null auto_increment primary key, shain_no varchar(20), password varchar(20), name varchar(40) ); insert into employee_info(shain_no,password,name) values (11111111,11111111,'名前'); ###試したこと ローマ字で記入したらログイン名が出てくるのですが、漢字で入力したい。 また、以下は確認したのですが、この状態でもうまく出て来ません。 mysql> show variables like 'char%'; +--------------------------+-------------------------------------------+ | 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 | /rdsdbbin/mysql-5.5.53.R1/share/charsets/ | +--------------------------+-------------------------------------------+ ###補足情報(言語/FW/ツール等のバージョンなど) mysqlのバージョン Server version: 5.5.53-log Source distribution phpのバージョン PHP 5.4.45

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

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

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

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

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

coba-coba

2017/05/04 03:52

使用しているOSはWindowsですか?Windowsのコマンドプロンプトを使っている場合は、表示にcp932を使っているので、上記設定では文字化けします。
coba-coba

2017/05/04 03:56

PHPでアクセスしている場合は、データベースを作成するときにutf8_general_ciを選択し、PHPのコードでnew PDO('……; charset=utf8', ……)を指定します。
guest

回答4

0

よくある文字化けはどこかで文字コードがおかしくなっているので起こるのですが、まず原因となる箇所を特定しないと解決が難しいです。

  1. tableに入っているデータ自体の文字コードは正しいか

 ・テーブルに文字化けした状態のデータが入っている
・ターミナルを使用している場合ターミナルが送る文字コードがutf8ではない
2. phpで取得したときの文字コードは正しいか
・phpの文字コードがおかしい
・意図しない文字コードでDBから取得したデータを扱っている等
3. php出力時の文字コードが正しいか
→htmlはブラウザにutf8で出力しているのにcontent-typeがsjisやEUCになっている等

まずこのあたりの確認をされるとよいかと思います。

投稿2017/05/03 15:37

編集2017/05/03 15:48
shiroyuki

総合スコア169

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

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

0

ベストアンサー

ご返信遅くなりました。
ご回答いただいた皆様、ありがとうございます。
まずは解決いたしました。

修正した点は、mysqli_set_charset($link,"utf-8");と記載して読み込むよう記載していたのですが、「utf-8」→「utf8」に変更したらデータベースの中身は変更せずに、うまく表示されました。

ハイフン「ー」があるなしだけでも表示されたり、されなかったりするものなのかがまだ疑問ではありますが、、、

使用環境は、Macのターミナルを使用してMySQLのデータベースを利用しております。
コードを書く際には、ATOMのテキストエディタを使って記載し、ターミナルにコピー、ペーストしてブラウザに読み込んで、今回のエラーが出ていた状態でした。

サーバーはローカル環境ともう一つありまして、ローカル環境では「utf-8」でもうまく表示されていて問題なかったのですが、もう一つのサーバーでは「utf8」にしないと表示されなかったという結果なのかなと思いました。

ちなみに、HTML5を利用して、<meta charset="UTF-8">の記載もしておりました。
ただ、今回の変更が根本的な解決策かはよくわかっておりませんが。

投稿2017/05/04 17:13

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

shiroyuki

2017/05/04 17:43 編集

問題ないとは思いますが、ターミナルの文字コードどちらに問題があるかどうか判別する方法があります。 1. UTF-8で(全角文字を含む)INSERT文を記述したのテキストファイルをローカルに用意する 2. そのファイルをサーバに転送 3. 転送したファイルを指定してSQLを実行(これで間違いなくDBにUTF-8のデータが入る) 4. ターミナルからも(全角文字を含む)INSERT文を実行 5. ターミナルでSELECT文を実行して3と4のデータを確認 3と4両方とも問題なければターミナルには問題ないです。 3で入れたデータが文字化けしていて場合はターミナルの文字コードがutf8ではないので設定を確認ください。 あとhtmlのmetaタグ以外にもwebサーバが返すレスポンスヘッダ内のcontent-typeが違っていたという可能性もあります。
guest

0

php.ini、もしくは

php

1<?php phpinfo();

のみのphpファイルを実行したときの出力で
mbstring周りがどうなっているかを点検する。
mbstring.internal_encodingとか
mbstring.http_inputやmbstring.http_outputや
mbstring.encoding_translationやmbstring.detect_orderとか。
もしかしてエンコーディングを自動で変換してしまうようなことをしていないかどうか。

また、
ページ遷移した先のページでhtml的にエンコーディングの指定は適切にやっているか。
html5なら

html

1<meta charset="UTF-8">

5以前なら

html

1<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

投稿2017/05/04 05:45

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

mb_convert_encoding()関数で日本語の文字コードを UTF-8 に強制的にそろえてみてはどうでしょうか。
文字エンコードを変換する(mb_convert_encoding)

投稿2017/05/03 20:41

seastar3

総合スコア2285

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問