首頁 > 後端開發 > php教程 > php讀mysql資料庫時出現亂碼如何解決

php讀mysql資料庫時出現亂碼如何解決

一个新手
發布: 2023-03-15 22:26:01
原創
1410 人瀏覽過

關於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。
透過設定character_set_client,告訴Mysql,PHP存進資料庫的是什麼編碼方式。
透過設定character_set_results,告訴Mysql,PHP需要取什麼樣編碼的資料。
透過設定character_set_connection,告訴Mysql,PHP查詢中的文本,使用什麼編碼。

3. 連接資料庫後,設定資料庫間傳輸字元時所使用的預設字元編碼。
使用mysqli::set_charset()或mysqli::query('set names utf8'),進行設定。
盡量使用mysqli::set_charset(mysqli:set_charset)而不是」SET NAMES」

  • $db = new mysqli('localhost','user','passwd','database_name');
    $db->set_charset('utf8');
    登入後複製

#複製程式碼
注意是utf8,不是utf-8
#(這裡有個問題就是,資料庫和php都已經統一了編碼,但如果沒有呼叫mysqli ::set_charset()函數時,讀出資料時仍會出現亂碼。
#

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中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板