将多个表的结果插入一个json_encode()

时间:2013-05-03 13:56:32

标签: php mysql json

请原谅我的语言错误,我说法语。

我在这个网站和其他地方做过一些研究,但我发现的并没有解决我的问题。

我正在建立一个人们可以发布故事的网站。我正在编写一个页面,作者应该能够看到他们的每个故事和章节。

我对两个表进行查询以获取故事和章节的标题。我有一个表“故事”,其中有每个故事的标题和摘要(和其他东西,如身份证和出版日期)。另一个叫做“章节”的表格,其中有每章的标题和它们所属故事的内容。

我想稍后在我的html中检索这些项目,以获得类似的内容:


故事标题1

第1章

第2章


所以我做一个json_encode(),但是JSONLint说我得到的json是无效的。 PHP对我来说是新手,我开始学习,所以我可能没有正确编写代码。

这是我的代码:

<?php
session_start();
require_once('connexion_db.php');

if($db=connect()){
    $userID = $_SESSION['id'];

    $arr = array();

    $reqRecits = $db->query('SELECT titre, id FROM recits WHERE user_id = '.$userID.'');
    $resRecits = $reqRecits->fetchAll(PDO::FETCH_ASSOC);

    foreach ($resRecits as $r){
        $recitID = $r['id'];
        $recitTitre = $r['titre'];

        $reqChapitres = $db->query('SELECT id, titre_chapitre FROM chapitres WHERE recit_id = '.$r['id'].'');
        $resChapitres = $reqChapitres->fetchAll(PDO::FETCH_ASSOC);

        foreach ($resChapitres as $c){
            $chapTitre = $c['titre_chapitre'];
        }

        $arr = array('titre'=>$recitTitre,'chapitre'=>$chapTitre);
        echo json_encode($arr, JSON_UNESCAPED_UNICODE);
    }

}else{
    echo "bdd non connectée.";
}
?>

我测试了提出的方法here,但结果更糟。 我不知道该怎么做:(

感谢您的帮助!

3 个答案:

答案 0 :(得分:2)

好像你希望内循环更像这样:

$chapTitre = array();
foreach ($resChapitres as $c){
  $chapTitre[] = $c['titre_chapitre'];
}

因此,您生成的JSON将包含所有章节标题。

另外,就目前而言,您列出了一系列未连接的JSON对象,它们应该是一个合法的JSON对象的单个数组。

foreach ($resRecits as $r){
    $recitID = $r['id'];
    $recitTitre = $r['titre'];

    $reqChapitres = $db->query('SELECT id, titre_chapitre FROM chapitres WHERE recit_id = '.$r['id'].'');
    $resChapitres = $reqChapitres->fetchAll(PDO::FETCH_ASSOC);

    $chapTitre = array();
    foreach ($resChapitres as $c){
      $chapTitre[] = $c['titre_chapitre'];
    }

    $arr[] = array('titre'=>$recitTitre,'chapitre'=>$chapTitre);
}

echo json_encode($arr, JSON_UNESCAPED_UNICODE);

将收集它们全部并作为列表输出。

[
  { 
    'titre': 'Title 1',
    'chaptitre': ['Chapter 1', 'Chapter 2']
  },
  { 
    'titre': 'Title 2',
    'chaptitre': ['Chapter 1', 'Chapter 2', 'Chapter 3']
  },
]

答案 1 :(得分:0)

<?php
session_start();
require_once('connexion_db.php');

if($db=connect()){
    $userID = $_SESSION['id'];

    $arr = array();

    $reqRecits = $db->query('SELECT titre, id FROM recits WHERE user_id = '.$userID.'');
    $resRecits = $reqRecits->fetchAll(PDO::FETCH_ASSOC);
    $chapTitres = array();
    foreach ($resRecits as $r){
        $recitID = $r['id'];
        $recitTitre = $r['titre'];

        $reqChapitres = $db->query('SELECT id, titre_chapitre FROM chapitres WHERE recit_id = '.$r['id'].'');
        $resChapitres = $reqChapitres->fetchAll(PDO::FETCH_ASSOC);


        foreach ($resChapitres as $c){
            $chapTitres[] = $c['titre_chapitre'];
        }



        $arr[] = array('titre' => $recitTitre, 'chaptitres' => $chapTitres);
    }

    echo json_encode($arr, JSON_UNESCAPED_UNICODE);

}else{
    echo "bdd non connectée.";
}
?>

答案 2 :(得分:0)

>  For Me this is Worked !


 <?php
    header('content-type: application/json');
    date_default_timezone_set('Asia/Dhaka');
    $DatabaseName = "";
    $HostPass = "";
    $HostUser = "";
    $HostName = "LocalHost";
    $db_connect = new mysqli($HostName, $HostUser, $HostPass, $DatabaseName);

    $userid = $_GET['id'];
    $status = $_GET['status'];
    $rows = array();
    $datas = array();

    $result = mysqli_query($db_connect, "SELECT id FROM drivers WHERE phone = '$userid'");
    if ($result)
    {
        $row = mysqli_fetch_assoc($result);
        $id = $row['id'];

        $result = mysqli_query($db_connect, "SELECT `delivery_id` , `date`, `time` FROM `driver_orders` WHERE driver_id='$id' AND `status` ='$status'");
        mysqli_set_charset($db_connect,"utf8");
        while ($row = mysqli_fetch_assoc($result))
        {

            $d_id = $row['delivery_id'];

            $data = mysqli_query($db_connect, "SELECT r_name,r_number,r_zone,r_address,amount FROM deliveries  WHERE id = '$d_id'");
            while ($row2 = mysqli_fetch_assoc($data))
            {
                $datas[] = array(
                    "r_name" => $row2['r_name'],
                    "delivery_id" => $row['delivery_id'],
                    "time"=> $row['time'],
                    "date"=> $row['date'],
                    "r_number" => $row2['r_number'],
                    "r_zone" => $row2['r_zone'],
                    "amount" => $row2['amount'],
                    "r_address" => $row2['r_address']

                );

            }



        }

    }

    echo json_encode($datas);

    ?>