這篇文章主要介紹了PHP中把數據庫查詢結果輸出為json格式簡單實例,本文直接給出示例代碼,都是非?;A的寫法,大家應該一看就明白,需要的朋友可以參考下
include/conn.php為數據庫鏈接文件,不會的網上搜索
- <?php
- include './include/conn.php'; //數據庫鏈接文件
- $sql_notice = mysql_query('SELECT * FROM gg_notice where enable = "1" limit 0,10');
- $notice = mysql_fetch_array($sql_notice, MYSQL_ASSOC);
- print_r ($notice);
- ?>
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <title>第一php網提供的教程--將數據庫讀取的數據生成json格式</title>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <!-- <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js" type="text/javascript"/></script> -->
- <script language=javascript>
- </script>
- </head>
- <body>
- <pre>
- <h1>請注意兩種方法生成的對象數組在結構上的區別</h1>
- <?php
- echo '<h1>法一</h1>';
- //假設以下數組是根據我們從數據庫讀取的數據生成的
- $jarr=array('total'=>239,'row'=>array(
- array('code'=>'001','name'=>'中國','addr'=>'Address 11','col4'=>'col4 data'),
- array('code'=>'002','name'=>'Name 2','addr'=>'Address 12','col4'=>'col4 data'),
- )
- );
- //法一:
- $jobj=new stdclass();//實例化stdclass,這是php內置的空類,可以用來傳遞數據,由于json_decode后的數據是以對象數組的形式存放的,
- //所以我們生成的時候也要把數據存儲在對象中
- foreach($jarr as $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>
新聞熱點
疑難解答