PHPがmysqlデータベースを読み込む際の文字化けの解決方法について
PHPがmysqlを読み込む際に、以下の箇所で文字セットが関係します。
1.データベーステーブル作成時にデータベーステーブルの文字セットを指定します。たとえば、
create table tablename ( id int not null auto_increment, title varchar(20) not null, primary key ('id') )DEFAULT CHARSET =UTF8;
2. mysql の文字セット
mysql には、character_set_client、character_set_results、character_set_connection の 3 つの重要な変数があります。
character_set_client を設定することで、PHP がデータベースに保存するエンコード方式を Mysql に伝えます。
character_set_results を設定することで、PHP がどのような種類のエンコードされたデータを取得する必要があるかを Mysql に伝えます。
character_set_connection を設定することで、PHP クエリ内のテキストにどのエンコーディングを使用するかを Mysql に指示します。
3. データベースに接続した後、データベース間で文字を送信するときに使用されるデフォルトの文字エンコーディングを設定します。
mysqli::set_charset() または mysqli::query('set names utf8') を使用して設定します。
「SET NAMES」の代わりに mysqli::set_charset(mysqli:set_charset) を使用してみてください
$db = new mysqli('localhost','user','passwd','database_name'); $db->set_charset('utf8');
コードをコピーしてください
utf-8 ではなく utf8 であることに注意してください
(ここで問題が発生しました。 つまり、データベースと PHP はエンコードを統一しましたが、mysqli::set_charset() 関数が呼び出されないと、データを読み込むときに文字化けが発生します。 , set names utf8 は以下の 3 つの文に相当します
SET character_set_client = utf8; SET character_set_results = utf8; SET character_set_connection = utf8; )
4. HTML ページで使用する文字セットをメタタグに設定します。
<meta http-equiv="content-type" content="text/html; charset=utf-8">
复制代码
5. php文本文件所使用的字符集。
在linux下可以用vim打开文件,输入
:set encoding
查看文件使用的字符集
要保证不乱码,需要保证文件自身的编码,HTML里指定的编码,PHP告诉Mysql的编码(包括character_set_client和character_set_results)统一。同时使用mysqli:set_charset()函数或”SET NAMES”。
针对“3”后面的问题,写了几个例子,测试链接数据库后,设置和不设置字符集时的结果。测试环境Ubuntu 12.04,MySQL 5.5,php 5.5.7。
结果如下:
(1) 数据库表字符集是utf8,不使用set names utf8
能正常插入、读出中文,但是在mysql中显示乱码
(2) 数据库表字符集是utf8,使用set names utf8
能正常插入、读出中文,mysql中显示正确
(3) 数据库表字符集不是utf8,使用set names utf8
mysql中显示,读出都是问号。
以上がPHPがmysqlデータベースを読み込むときに文字化けする問題を解決する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。