PHP中把数据库查询结果输出为json格式简单实例
include/conn.php为数据库链接文件,不会的网上搜索
<?php include'./include/conn.php';//数据库链接文件 $sql_notice=mysql_query('SELECT*FROMgg_noticewhereenable="1"limit0,10'); $notice=mysql_fetch_array($sql_notice,MYSQL_ASSOC); print_r($notice); ?> <!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <htmlxmlns="http://www.w3.org/1999/xhtml"> <head> <title>第一php网提供的教程--将数据库读取的数据生成json格式</title> <metahttp-equiv="Content-Type"content="text/html;charset=utf-8"/> <!--<scriptsrc="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"type="text/javascript"/></script>--> <scriptlanguage=javascript> </script> </head> <body> <pre> <h1>请注意两种方法生成的对象数组在结构上的区别</h1> <?php echo'<h1>法一</h1>'; //假设以下数组是根据我们从数据库读取的数据生成的 $jarr=array('total'=>239,'row'=>array( array('code'=>'001','name'=>'中国','addr'=>'Address11','col4'=>'col4data'), array('code'=>'002','name'=>'Name2','addr'=>'Address12','col4'=>'col4data'), ) ); //法一: $jobj=newstdclass();//实例化stdclass,这是php内置的空类,可以用来传递数据,由于json_decode后的数据是以对象数组的形式存放的, //所以我们生成的时候也要把数据存储在对象中 foreach($jarras$key=>$value){ $jobj->$key=$value; } print_r($jobj);//打印传递属性后的对象 echo'使用$jobj->row[0][\'code\']输出数组元素:'.$jobj->row[0]['code'].'<br>'; echo'编码后的json字符串:'.json_encode($jobj).'<br>';//打印编码后的json字符串 echo'<hr>'; //法二: echo'<h1>法二</h1>'; echo'编码后的json字符串:'; echo$str=json_encode($jarr);//将数组进行json编码 echo'<br>'; $arr=json_decode($str);//再进行json解码 print_r($arr);//打印解码后的数组,数据存储在对象数组中 echo'使用$arr->row[0]->code输出数组元素:'.$arr->row[0]->code; ?> </body> </html>