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

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

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

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

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

我想稍后在我的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提出的方法,但结果更糟.
我不知道该怎么办 :(

谢谢你的帮助!

最佳答案 看起来你想要内循环更像这样:

$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']
  },
]
点赞