本篇文章給大家分享的是有關(guān)php數(shù)據(jù)庫(kù)查詢亂碼怎么辦,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

成都創(chuàng)新互聯(lián)公司2013年開(kāi)創(chuàng)至今,先為南明等服務(wù)建站,南明等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為南明企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。
php數(shù)據(jù)庫(kù)查詢亂碼的解決辦法:首先在MySQL Command Line Client創(chuàng)建數(shù)據(jù)庫(kù);然后指定數(shù)據(jù)庫(kù)的字符集,讓mysql同時(shí)支持多種編碼的數(shù)據(jù)庫(kù);最后對(duì)創(chuàng)建好的數(shù)據(jù)庫(kù)進(jìn)行操作即可。
亂碼解決方法
要解決亂碼問(wèn)題,首先必須弄清楚自己數(shù)據(jù)庫(kù)用什么編碼。如果沒(méi)有指明,將是默認(rèn)的latin1。
我們用得最多的應(yīng)該是這3種字符集 gb2312,gbk,utf8。
那么我們?nèi)绾稳ブ付〝?shù)據(jù)庫(kù)的字符集呢?下面也gbk為例
【在MySQL Command Line Client創(chuàng)建數(shù)據(jù)庫(kù)】
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;
就是指定數(shù)據(jù)庫(kù)的字符集,COLLATE (校勘),讓mysql同時(shí)支持多種編碼的數(shù)據(jù)庫(kù)。
當(dāng)然我們也可以通過(guò)如下指令修改數(shù)據(jù)庫(kù)的字符集
alter database da_name default character set 'charset'.
客戶端以 gbk格式發(fā)送 ,可以采用下述配置:
SET character_set_client='gbk' SET character_set_connection='gbk' SET character_set_results='gbk'
這個(gè)配置就等價(jià)于 SET NAMES 'gbk'。
現(xiàn)在對(duì)剛才創(chuàng)建的數(shù)據(jù)庫(kù)操作
mysql> use test; Database changed mysql> insert into mysqlcode values(null,'php愛(ài)好者'); ERROR 1406 (22001): Data too long for column 'content' at row 1
沒(méi)有指定字符集為gbk,插入時(shí)出錯(cuò)
mysql> set names 'gbk'; Query OK, 0 rows affected (0.02 sec)
指定字符集為 gbk
mysql> insert into mysqlcode values(null,'php愛(ài)好者'); Query OK, 1 row affected (0.00 sec)
插入成功
mysql> select * from mysqlcode; +----+-----------+ | id | content | +----+-----------+ | 1 | php愛(ài)好著 | +----+-----------+ 1 row in set (0.00 sec)
在沒(méi)有指定字符集gbk時(shí)讀取也會(huì)出現(xiàn)亂碼,如下
mysql> select * from mysqlcode; +----+---------+ | id | content | +----+---------+ | 1 | php??? | +----+---------+ 1 row in set (0.00 sec)
【在phpmyadmin創(chuàng)建數(shù)據(jù)庫(kù),并指定字符集】
表類型根據(jù)自己需要選,這里選MyISAM(支持全文檢索);
整理選擇 gbk_chinese_ci 也就是gbk字符集
gbk_bin 簡(jiǎn)體中文, 二進(jìn)制。gbk_chinese_ci 簡(jiǎn)體中文, 不區(qū)分大小寫。
在剛才創(chuàng)建的數(shù)據(jù)庫(kù)插入數(shù)據(jù)庫(kù)
再瀏覽時(shí)發(fā)現(xiàn)是亂碼
為什么呢?是因?yàn)閿?shù)據(jù)庫(kù)為gbk字符集,而我們操作時(shí)沒(méi)有指定為gbk
回到數(shù)據(jù)庫(kù)首頁(yè)
可以看到 mysql 連接校對(duì)默認(rèn)的latin1_bin。我們將其改為gbk_chinese_ci
再插入一條數(shù)據(jù)。看,這條已經(jīng)正常了
【解決php讀取數(shù)據(jù)庫(kù)亂碼】
仍以數(shù)據(jù)庫(kù)mysqlcode為例
<?php
$conn = mysql_connect("localhost","root","89973645");
mysql_query("set names 'gbk'");//這就是指定數(shù)據(jù)庫(kù)字符集,一般放在連接數(shù)據(jù)庫(kù)后面就系了
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">內(nèi)容</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'");注釋掉,肯定時(shí)亂碼
加上那句又正常了
一句話
你數(shù)據(jù)庫(kù)用什么編碼,在對(duì)數(shù)據(jù)庫(kù)操作之前就set names '你的編碼';
以上就是php數(shù)據(jù)庫(kù)查詢亂碼怎么辦,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)頁(yè)題目:php數(shù)據(jù)庫(kù)查詢亂碼怎么辦
文章路徑:http://www.chinadenli.net/article38/pgdgsp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、品牌網(wǎng)站建設(shè)、關(guān)鍵詞優(yōu)化、外貿(mào)網(wǎng)站建設(shè)、微信小程序、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)