91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

php數據庫查詢亂碼怎么辦

發布時間:2020-07-24 16:32:03 來源:億速云 閱讀:145 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關php數據庫查詢亂碼怎么辦,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

php數據庫查詢亂碼的解決辦法:首先在MySQL Command Line Client創建數據庫;然后指定數據庫的字符集,讓mysql同時支持多種編碼的數據庫;最后對創建好的數據庫進行操作即可。

亂碼解決方法

要解決亂碼問題,首先必須弄清楚自己數據庫用什么編碼。如果沒有指明,將是默認的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 'gbk'");//這就是指定數據庫字符集,一般放在連接數據庫后面就系了 
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['id']."</td> 
    <td>".$row['content']."</td> 
 </tr>"; 
}?>   
</table> 
</body> 
</html> 
<?php mysql_free_result($result);?>

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

加上那句又正常了

一句話

你數據庫用什么編碼,在對數據庫操作之前就set names '你的編碼';

以上就是php數據庫查詢亂碼怎么辦,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙胜| 泰和县| 贵州省| 鄂托克前旗| 漯河市| 永德县| 赫章县| 濮阳县| 台山市| 肇东市| 宁城县| 武定县| 大安市| 藁城市| 峡江县| 阿克苏市| 揭东县| 财经| 兴化市| 綦江县| 渭源县| 密云县| 抚州市| 始兴县| 武胜县| 陇川县| 台中市| 穆棱市| 公主岭市| 沙洋县| 湖南省| 怀远县| 天等县| 金堂县| 阳春市| 岗巴县| 新安县| 庆云县| 香港| 岫岩| 金沙县|