首頁  >  文章  >  後端開發  >  怎麼解決php資料庫查詢亂碼問題

怎麼解決php資料庫查詢亂碼問題

藏色散人
藏色散人原創
2020-07-24 09:57:153265瀏覽

php資料庫查詢亂碼的解決方法:首先在MySQL Command Line Client建立資料庫;然後指定資料庫的字元集,讓mysql同時支援多種編碼的資料庫;最後對建立好的資料庫進行操作即可。

怎麼解決php資料庫查詢亂碼問題

亂碼解決方法

#推薦:《PHP教學

要解決亂碼問題,首先必須弄清楚自己資料庫用什麼編碼。如果沒有指明,將是預設的latin1。

我們用得最多的應該是這3種字元集 gb2312,gbk,utf8。

那我們要如何去指定資料庫的字元集呢?下面也gbk為例

【在MySQL Command Line Client建立資料庫】

mysql> CREATE TABLE `mysqlcode` (
    -> `id` TINYINT( 255 ) UNSIGNED NOT NULL AUTO_INCREMENT PRIMARY KEY ,
    -> `content` VARCHAR( 255 ) NOT NULL
    -> ) TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;
Query OK, 0 rows affected, 1 warning (0.03 sec)
mysql> desc mysqlcode;
+---------+-----------------------+------+-----+---------+----------------+
| Field   | Type                  | Null | Key | Default | Extra          |
+---------+-----------------------+------+-----+---------+----------------+
| id      | tinyint(255) unsigned | NO   | PRI |         | auto_increment |
| content | varchar(255)          | NO   |     |         |                |
+---------+-----------------------+------+-----+---------+----------------+
2 rows in set (0.02 sec)

其中後面的TYPE = MYISAM CHARACTER SET gbk COLLATE gbk_chinese_ci;

就是指定資料庫的字元集,COLLATE (校勘),讓mysql同時支援多種編碼的資料庫。

當然我們也可以透過以下指令修改資料庫的字元集

alter database da_name default character set 'charset'.

客戶端以gbk格式傳送,可以採用下述設定:

SET character_set_client='gbk'
SET character_set_connection='gbk'
SET character_set_results='gbk'

這個設定就等價於SET NAMES 'gbk'。

現在對剛剛建立的資料庫操作

mysql> use test;
Database changed
mysql> insert into mysqlcode values(null,'php爱好者');
ERROR 1406 (22001): Data too long for column 'content' at row 1

沒有指定字元集為gbk,插入時發生錯誤

mysql> set names 'gbk';
Query OK, 0 rows affected (0.02 sec)

指定字元集為gbk

mysql> insert into mysqlcode values(null,'php爱好者');
Query OK, 1 row affected (0.00 sec)

插入成功

mysql> select * from mysqlcode;
+----+-----------+
| id | content   |
+----+-----------+
| 1  | php爱好着 |
+----+-----------+
1 row in set (0.00 sec)

在沒有指定字元集gbk時讀取也會出現亂碼,如下

mysql> select * from mysqlcode;
+----+---------+
| id | content |
+----+---------+
| 1  | php???  |
+----+---------+
1 row in set (0.00 sec)

【在phpmyadmin建立資料庫,並指定字元集】

#表類型根據自己需要選,這裡選MyISAM(支援全文檢索);

整理選擇gbk_chinese_ci 也就是gbk字元集

gbk_bin 簡體中文, 二進位。 gbk_chinese_ci 簡體中文, 不區分大小寫。

在剛才建立的資料庫插入資料庫

再瀏覽時發現是亂碼

為什麼呢?是因為資料庫為gbk字元集,而我們操作時沒有指定為gbk

回到資料庫首頁

可以看到 mysql 連線校對預設的latin1_bin。我們將其改為gbk_chinese_ci

再插入一條資料。看,這已經正常了

【解決php讀取資料庫亂碼】

仍以資料庫mysqlcode為例 

<?php 
$conn = mysql_connect("localhost","root","89973645"); 
mysql_query("set names &#39;gbk&#39;");//这就是指定数据库字符集,一般放在连接数据库后面就系了 
mysql_select_db("test"); 
 
$sql = "select * from mysqlcode"; 
$result = mysql_query($sql,$conn); 
 
?> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>mysql 字符编码</title> 
</head> 
 
<body> 
<table width="300" height="32" border="1" align="center" cellpadding="0" cellspacing="0"> 
 <tr> 
    <td width="71" align="center">id</td> 
    <td width="229" align="center">内容</td> 
 </tr> 
 <?php while($row = mysql_fetch_assoc($result)){ 
 echo "   
 <tr> 
    <td align=/"center/">".$row[&#39;id&#39;]."</td> 
    <td>".$row[&#39;content&#39;]."</td> 
 </tr>"; 
}?>   
</table> 
</body> 
</html> 
<?php mysql_free_result($result);?>

 如果我們將mysql_query("set names 'gbk '");註解掉,肯定時亂碼

加上那句又正常了

一句話

你資料庫用什麼編碼,在對資料庫操作之前就set names '你的編碼';

以上是怎麼解決php資料庫查詢亂碼問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn