欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP如何將數(shù)據(jù)庫查詢結(jié)果輸出為json格式

 更新時(shí)間:2022年02月08日 10:42:39   作者:Yiven  
JSON數(shù)據(jù)格式相比xml的解析難度較低,配合Ajax技術(shù)的使用使得前端獲取數(shù)據(jù),呈現(xiàn)數(shù)據(jù)非常方便,所以下面這篇文章主要給大家介紹了關(guān)于PHP如何將數(shù)據(jù)庫查詢結(jié)果輸出為json格式的相關(guān)資料,需要的朋友可以參考下

直接上實(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布局助手詳解

    這篇文章主要介紹了Zend Framework教程之Zend_Layout布局助手用法,結(jié)合實(shí)例形式詳細(xì)分析了Layout布局的相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-03-03
  • PHP之header函數(shù)詳解

    PHP之header函數(shù)詳解

    這篇文章主要介紹了PHP之header函數(shù)詳解,小編覺得這個(gè)header函數(shù)的技術(shù)點(diǎn)還是比較重要的,感興趣的同學(xué)可以研究下
    2021-03-03
  • PHP如何通過傳引用的思想實(shí)現(xiàn)無限分類(代碼簡單)

    PHP如何通過傳引用的思想實(shí)現(xiàn)無限分類(代碼簡單)

    本文給大家介紹php引用傳遞,如何通過引用出的思想實(shí)現(xiàn)無限分類,代碼超簡單,需要的朋友可以借鑒下
    2015-10-10
  • Laravel事件系統(tǒng)實(shí)現(xiàn)瀏覽量的統(tǒng)計(jì)

    Laravel事件系統(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-03
  • ECMall支持SSL連接郵件服務(wù)器的配置方法詳解

    ECMall支持SSL連接郵件服務(wù)器的配置方法詳解

    這篇文章主要介紹了ECMall支持SSL連接郵件服務(wù)器的配置方法詳解
    2014-05-05
  • ThinkPHP公共配置文件與各自項(xiàng)目中配置文件組合的方法

    ThinkPHP公共配置文件與各自項(xiàng)目中配置文件組合的方法

    這篇文章主要介紹了ThinkPHP公共配置文件與各自項(xiàng)目中配置文件組合的方法,涉及array_merge函數(shù)將多個(gè)數(shù)組合并的方法,是ThinkPHP項(xiàng)目開發(fā)中非常實(shí)用的技巧,需要的朋友可以參考下
    2014-11-11
  • 利用PHPStorm如何開發(fā)Laravel應(yīng)用詳解

    利用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-08
  • PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程

    PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程

    這篇文章主要介紹了PHP連接和操作MySQL數(shù)據(jù)庫基礎(chǔ)教程,本文講解了mysql擴(kuò)展、連接數(shù)據(jù)庫、與數(shù)據(jù)庫交互等內(nèi)容,需要的朋友可以參考下
    2014-09-09
  • PHP 計(jì)算至少是其他數(shù)字兩倍的最大數(shù)的實(shí)現(xiàn)代碼

    PHP 計(jì)算至少是其他數(shù)字兩倍的最大數(shù)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了PHP 計(jì)算至少是其他數(shù)字兩倍的最大數(shù),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Laravel 微信小程序后端搭建步驟詳解

    Laravel 微信小程序后端搭建步驟詳解

    這篇文章主要介紹了Laravel 微信小程序后端搭建步驟詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11

最新評(píng)論