php mysql 转码_php数据库读出乱码的解决方法 - php数据库读出乱码是说明原因及其解决方法...

当从后台读取PHP数据库时遇到乱码,通常是由于编码设置不正确导致的。解决方法包括在PHP中设置Content-Type为UTF-8,或者在数据库连接后执行SET NAMES 'utf8'。确保数据库、表和字段的编码一致,例如设置为'utf8_general_ci'。在插入和读取数据时,需指定正确的字符集,如SET NAMES 'gbk',以避免乱码问题。
摘要由CSDN通过智能技术生成

php数据库读出乱码的解决方法

从后台读取数据时,通常会出现乱码情况,比如“汉字”变成“?”等,造成这种情况的原因通常是编码设置不对,解决方法如下:

第一种方法:在php中添加如下代码,将编码格式设为“utf-8”,代码如下:

header(“Content-Type: text/html; charset=UTF-8”);

第二种方法:在php中添加另外一行代码,同样用来转码,代码如下:

$conn = mysqli_connect($servername, $username, $password, $mysqlname);

$conn-》query(“SET NAMES utf8”);

该种情况是先创建链接,之后再转码。

另外,在使用数据库时,直接手动(非代码)建表,通常会在表中输入汉字时,浏览时无法显示或显示为“?”,造成这种情况的原因也是编码问题,解决方案如下:

在建表或建库时,表和库的编码格式一定要统一,设置成:“utf8_general_ci”,如下图:

0ff2c3947d4c00fc8e25d4e5b426bf05.png

要解决乱码问题,首先必须弄清楚自己数据库用什么编码。如果没有指明,将是默认的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创建数据库,并指定字符集】

34995634459ecbeee1d35f0e53a40e00.png

表类型根据自己需要选,这里选MyISAM(支持全文检索);

整理选择 gbk_chinese_ci 也就是gbk字符集

gbk_bin 简体中文, 二进制。gbk_chinese_ci 简体中文, 不区分大小写。

在刚才创建的数据库插入数据库

37f4efe65b728411942fb7df75a16365.png

为什么呢?是因为数据库为gbk字符集,而我们操作时没有指定为gbk

回到数据库首页

dec7160c7634a8e0cd52f425e842f348.png

可以看到 mysql 连接校对默认的latin1_bin。我们将其改为gbk_chinese_ci

205241d18cd383b12b12a1ee2fb850f6.png

【解决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);?》

2d85747fcddc1e48bbbe6459bdb3a6ae.png

你数据库用什么编码,在对数据库操作之前就set names ‘你的编码’;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值