PHP如何將數(shù)據(jù)庫(kù)查詢(xún)結(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);
// 檢測(cè)連接
$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)語(yǔ)句中,由于每次刪除 row數(shù)組長(zhǎng)度都減小
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)?。∵€有另外一種寫(xiě)法
<?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);
// 檢測(cè)連接
$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)語(yǔ)句中,由于每次刪除 row數(shù)組長(zhǎng)度都減小
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)置的空類(lèi),可以用來(lá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"}}
這樣一來(lái),中括號(hào)沒(méi)有了,數(shù)組也成為了有序的數(shù)組!
總結(jié)
到此這篇關(guān)于PHP如何將數(shù)據(jù)庫(kù)查詢(xún)結(jié)果輸出為json格式的文章就介紹到這了,更多相關(guān)PHP數(shù)據(jù)庫(kù)查詢(xún)結(jié)果輸出json內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Laravel5.1自定義500錯(cuò)誤頁(yè)面示例
這篇文章主要介紹了Laravel5.1自定義500錯(cuò)誤頁(yè)面的方法,結(jié)合實(shí)例形式分析了Laravel5.1自定義錯(cuò)誤頁(yè)面的相關(guān)文件修改技巧,需要的朋友可以參考下2016-10-10
php分頁(yè)原理 分頁(yè)代碼 分頁(yè)類(lèi)制作教程
這篇文章主要為大家詳細(xì)介紹了php分頁(yè)原理,php分頁(yè)代碼,php分頁(yè)類(lèi)制作教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
PHP+jQuery 注冊(cè)模塊開(kāi)發(fā)詳解
本文主要是記錄了開(kāi)發(fā)PHP+jQuery注冊(cè)模塊的全過(guò)程,包含填寫(xiě)欄目用戶(hù)名、郵箱、密碼、重復(fù)密碼、驗(yàn)證碼等,非常的詳細(xì),推薦給大家2014-10-10
PHP實(shí)現(xiàn)一個(gè)簡(jiǎn)單url路由功能實(shí)例
這篇文章主要介紹了PHP實(shí)現(xiàn)一個(gè)簡(jiǎn)單url路由功能實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-11-11
ThinkPHP設(shè)置禁止百度等搜索引擎轉(zhuǎn)碼(簡(jiǎn)單實(shí)用)
這篇文章主要介紹了ThinkPHP設(shè)置禁止百度等搜索引擎轉(zhuǎn)碼(簡(jiǎn)單實(shí)用)的相關(guān)資料,需要的朋友可以參考下2016-02-02
解決PHP使用CURL發(fā)送GET請(qǐng)求時(shí)傳遞參數(shù)的問(wèn)題
今天小編就為大家分享一篇解決PHP使用CURL發(fā)送GET請(qǐng)求時(shí)傳遞參數(shù)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
laravel-admin select框默認(rèn)選中的方法
今天小編就為大家分享一篇laravel-admin select框默認(rèn)選中的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

