php将结果集输出为json,PHP中把数据库查询结果输出为json格式

header("Content-type:text/html;charset=utf-8");//字符编码设置

$servername = "localhost";$username = "root";$password = "root";$dbname = "tjks";//创建连接

$con =mysqli_connect($servername, $username, $password, $dbname);//检测连接

$sql = "SELECT * FROM brands";$result = mysqli_query($con,$sql);if (!$result) {printf("Error: %s\n", mysqli_error($con));exit();

}$jarr = array();while ($rows=mysqli_fetch_array($result,MYSQL_ASSOC)){$count=count($rows);//不能在循环语句中,由于每次删除 row数组长度都减小

for($i=0;$i

}array_push($jarr,$rows);

}print_r($jarr);//查看数组

echo "
";echo ‘


‘;

echo ‘编码后的json字符串:‘;echo $str=json_encode($jarr);//将数组进行json编码

echo ‘
‘;$arr=json_decode($str);//再进行json解码

echo ‘解码后的数组:‘;print_r($arr);//打印解码后的数组,数据存储在对象数组中

mysqli_close($con);?>

输出内容如下:

Array ( [id] => 1 [name] => GNC ) Array ( [id] => 2 [name] => TCBJ ) Array ( [id] => 3 [name] =>TJKS )

Unicode编码后的json数据: [{"id":"1","name":"GNC"},{"id":"2","name":"TCBJ"},{"id":"3","name":"TJKS"}]

可以看到,直接进行json_encode();编码,是将三个数组分别转为了json格式,而且两端会出现中括号!!还有另外一种写法

$servername = "localhost";$username = "root";$password = "root";$dbname = "tjks";//创建连接

$con =mysqli_connect($servername, $username, $password, $dbname);//检测连接

$sql = "SELECT * FROM brands";$result = mysqli_query($con,$sql);if (!$result) {printf("Error: %s\n", mysqli_error($con));exit();

}$jarr = array();while ($rows=mysqli_fetch_array($result,MYSQL_ASSOC)){$count=count($rows);//不能在循环语句中,由于每次删除 row数组长度都减小

for($i=0;$i

}array_push($jarr,$rows);

}print_r($jarr);//查看数组

echo "
";echo ‘


‘;

$jobj=new stdclass();//实例化stdclass,这是php内置的空类,可以用来传递数据,由于json_encode后的数据是以对象数组的形式存放的,

//所以我们生成的时候也要把数据存储在对象中

foreach($jarr as $key=>$value){$jobj->$key=$value;

}echo ‘传递属性后的对象:‘;print_r($jobj);//打印传递属性后的对象

echo ‘
‘;echo ‘编码后的json字符串:‘.json_encode($jobj).‘
‘;//打印编码后的json字符串

mysqli_close($con);?>

输出内容如下:

Array ( [0] => Array ( [id] => 1 [name] => GNC ) [1] => Array ( [id] => 2 [name] => TCBJ ) [2] => Array ( [id] => 3 [name] =>TJKS ) )

传递属性后的对象:stdClassObject ( [0] => Array ( [id] => 1 [name] => GNC ) [1] => Array ( [id] => 2 [name] => TCBJ ) [2] => Array ( [id] => 3 [name] =>TJKS ) )

编码后的json字符串:{"0":{"id":"1","name":"GNC"},"1":{"id":"2","name":"TCBJ"},"2":{"id":"3","name":"TJKS"}}

这样一来,中括号没有了,数组也成为了有序的数组!

PHP中把数据库查询结果输出为json格式

标签:query   password   head   sso   key   [1]   查看   数据库   class

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:http://www.cnblogs.com/yiven/p/6491019.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值