PHP如何將數(shù)據(jù)庫查詢結(jié)果輸出為json格式
直接上實(shí)例代碼
<?php header("Content-type:text/html;charset=utf-8");//字符編碼設(shè)置 $servername = "localhost"; $username = "root"; $password = "root"; $dbname = "tjks"; // 創(chuàng)建連接 $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);//不能在循環(huán)語句中,由于每次刪除 row數(shù)組長度都減小 for($i=0;$i<$count;$i++){ unset($rows[$i]);//刪除冗余數(shù)據(jù) } array_push($jarr,$rows); } print_r($jarr);//查看數(shù)組 echo "<br/>"; echo '<hr>'; echo '編碼后的json字符串:'; echo $str=json_encode($jarr);//將數(shù)組進(jìn)行json編碼 echo '<br>'; $arr=json_decode($str);//再進(jìn)行json解碼 echo '解碼后的數(shù)組:'; print_r($arr);//打印解碼后的數(shù)組,數(shù)據(jù)存儲(chǔ)在對(duì)象數(shù)組中 mysqli_close($con); ?>
輸出內(nèi)容如下:
Array ( [id] => 1 [name] => GNC ) Array ( [id] => 2 [name] => TCBJ ) Array ( [id] => 3 [name] => TJKS )
Unicode編碼后的json數(shù)據(jù): [{"id":"1","name":"GNC"},{"id":"2","name":"TCBJ"},{"id":"3","name":"TJKS"}]
可以看到,直接進(jìn)行json_encode();編碼,是將三個(gè)數(shù)組分別轉(zhuǎn)為了json格式,而且兩端會(huì)出現(xiàn)中括號(hào)??!還有另外一種寫法
<?php header("Content-type:text/html;charset=utf-8");//字符編碼設(shè)置 $servername = "localhost"; $username = "root"; $password = "root"; $dbname = "tjks"; // 創(chuàng)建連接 $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);//不能在循環(huán)語句中,由于每次刪除 row數(shù)組長度都減小 for($i=0;$i<$count;$i++){ unset($rows[$i]);//刪除冗余數(shù)據(jù) } array_push($jarr,$rows); } print_r($jarr);//查看數(shù)組 echo "<br/>"; echo '<hr>'; $jobj=new stdclass();//實(shí)例化stdclass,這是php內(nèi)置的空類,可以用來傳遞數(shù)據(jù),由于json_encode后的數(shù)據(jù)是以對(duì)象數(shù)組的形式存放的, //所以我們生成的時(shí)候也要把數(shù)據(jù)存儲(chǔ)在對(duì)象中 foreach($jarr as $key=>$value){ $jobj->$key=$value; } echo '傳遞屬性后的對(duì)象:'; print_r($jobj);//打印傳遞屬性后的對(duì)象 echo '<br>'; echo '編碼后的json字符串:'.json_encode($jobj).'<br>';//打印編碼后的json字符串 mysqli_close($con); ?>
輸出內(nèi)容如下:
Array ( [0] => Array ( [id] => 1 [name] => GNC ) [1] => Array ( [id] => 2 [name] => TCBJ ) [2] => Array ( [id] => 3 [name] => TJKS ) )
傳遞屬性后的對(duì)象:stdClass Object ( [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"}}
這樣一來,中括號(hào)沒有了,數(shù)組也成為了有序的數(shù)組!
總結(jié)
到此這篇關(guān)于PHP如何將數(shù)據(jù)庫查詢結(jié)果輸出為json格式的文章就介紹到這了,更多相關(guān)PHP數(shù)據(jù)庫查詢結(jié)果輸出json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Zend Framework教程之Zend_Layout布局助手詳解
這篇文章主要介紹了Zend Framework教程之Zend_Layout布局助手用法,結(jié)合實(shí)例形式詳細(xì)分析了Layout布局的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-03-03PHP如何通過傳引用的思想實(shí)現(xiàn)無限分類(代碼簡單)
本文給大家介紹php引用傳遞,如何通過引用出的思想實(shí)現(xiàn)無限分類,代碼超簡單,需要的朋友可以借鑒下2015-10-10Laravel事件系統(tǒng)實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì)
Laravel的事件系統(tǒng)提供了一種簡單而強(qiáng)大的方式來實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì),通過創(chuàng)建瀏覽事件和事件監(jiān)聽器,以及在合適的地方觸發(fā)事件,我們可以輕松地實(shí)現(xiàn)網(wǎng)頁瀏覽量的統(tǒng)計(jì)功能,本文將介紹如何使用Laravel的事件系統(tǒng)來實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì)2024-03-03ThinkPHP公共配置文件與各自項(xiàng)目中配置文件組合的方法
這篇文章主要介紹了ThinkPHP公共配置文件與各自項(xiàng)目中配置文件組合的方法,涉及array_merge函數(shù)將多個(gè)數(shù)組合并的方法,是ThinkPHP項(xiàng)目開發(fā)中非常實(shí)用的技巧,需要的朋友可以參考下2014-11-11利用PHPStorm如何開發(fā)Laravel應(yīng)用詳解
這篇文章主要給大家介紹了關(guān)于利用PHPStorm如何開發(fā)Laravel應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)下吧。2017-08-08PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程
這篇文章主要介紹了PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程,本文講解了mysql擴(kuò)展、連接數(shù)據(jù)庫、與數(shù)據(jù)庫交互等內(nèi)容,需要的朋友可以參考下2014-09-09PHP 計(jì)算至少是其他數(shù)字兩倍的最大數(shù)的實(shí)現(xiàn)代碼
這篇文章主要介紹了PHP 計(jì)算至少是其他數(shù)字兩倍的最大數(shù),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05