php中pdo查询出来的数据转换成json格式(含中文乱码解决方法)

本文介绍了在PHP中使用PDO查询数据库后如何将数据转换为JSON格式,并解决过程中遇到的中文乱码问题。通过设置PDO连接属性防止乱码,然后将二维数组转换为一维数组,最后使用json_encode进行转换,注意在出现中文乱码时调整字符编码为UTF8并使用JSON_UNESCAPED_UNICODE参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们平时在数据库中读取出来的数据一般是二维关联数组
在这里插入图片描述
首先做好前期准备

//创建连接
	
	$dsn="mysql:dbname=secondhand;host=localhost";
	$db_user='root';
	$db_pass='root';
		try{
			$pdo=new PDO($dsn,$db_user,$db_pass,array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'gbk'"));
			}catch(PDOException $e){
				echo '数据库连接失败'.$e->getMessage();
	}

array(PDO::MYSQL_ATTR_INIT_COMMAND => “SET NAMES ‘gbk’”) 这段是防止出现中文乱码

//查询
	$sql="select * from classify";
	$res=$pdo->query($sql);
	while ($row = $res->fetchAll(PDO::FETCH_ASSOC)){
    print_r($row);
	}

如图,我们先转成一维数组
print_r($row); 进行修改就行

 //查询
	$sql="select * from classify";
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值