欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php如何将结果集转json

程序员文章站 2022-03-22 22:01:05
...

php将结果集转json的方法:首先将数据库中的数据存储到一个数组;然后对这个数组进行编码;最后通过“ json_encode”函数进行json编码并打印结果即可。

php如何将结果集转json

推荐:《PHP视频教程

PHP将数据库查询内容转换为JSON格式且显示中文

最近写android,开始写服务器了。最终服务器的语言就先定为PHP,因为以前写过一阵子网页,所以就先用PHP试试水。

那么首先为了实现android前端与服务器交互,那么我们服务器传输的数据就要先变为JSON格式。

那么如何将数据库中的内容查询出来,并且使其转变为JSON格式呢?代码如下:

if(isset($_GET["userid"])){
    $userid=$_GET["userid"];
    echo $userid;
    $sql="select * from user where userid='$userid'";
}
$result=mysqli_query($conn,$sql);
if (!$result) {
    printf("Error: %s\n", mysqli_error($conn));
    exit();
}
 
$jarr = array();
while ($rows=mysqli_fetch_array($result,MYSQL_ASSOC)){
    $count=count($rows);//不能在循环语句中,由于每次删除 row数组长度都减小
    for($i=0;$i<$count;$i++){
        unset($rows[$i]);//删除冗余数据
    }
    array_push($jarr,$rows);
}
print_r($jarr);//查看数组
echo "<br/>";
 
echo '<hr>';
 
echo '编码后的json字符串:';
echo $str=json_encode($jarr,JSON_UNESCAPED_UNICODE);//将数组进行json编码
echo '<br>';
$arr=json_decode($str);//再进行json解码
echo '解码后的数组:';
print_r($arr);//打印解码后的数组,数据存储在对象数组中
mysqli_close($conn);

其实原理很简单,就是将数据库中的数据存储到一个数组之后,再对这个数组进行编码。但是,我们需要注意的是,如果数据库中有中文,而对其进行JSON编码之后,仍然想使其变为中文。我们需要在 json_encode()中加上一个选项, JSON_UNESCAPED_UNICODE。也就是避免对中文用utf-8编码。上面的代码已经实现。

以上就是php如何将结果集转json的详细内容,更多请关注其它相关文章!

相关标签: php json