使用PHP从MariaDB数据创建嵌套JSON

时间:2017-03-27 15:04:20

标签: php mysql json mysqli mariadb

我需要帮助 我有3张桌子 1. post_table with columns:id_post,post_text。
2. attach_picture with column:id_picture,picture_name,id_post。
3. comment_table,列:id_comment,comment_text,id_post。

<?php 
$con = mysqli_connect('localhost', 'root', '', 'postingan');

// Check connection
if (mysqli_connect_errno())
  {
  echo "Failed to connect to MySQL: " . mysqli_connect_error();
  }
  else {
    echo "success";
  }

$postinganlist_array  = array();
$postingan_array = array();
$image_array = array();
$comment_array = array();
$fetch_postingan = mysqli_query($mysqli, 
    "SELECT id_post, post_text FROM post_table")
 or die(mysqli_error($mysqli));
while ($row_postingan = mysqli_fetch_assoc($fetch_postingan)){
$postingan_array['id'] = $row_postingan['id_post'];
$postingan_array['text'] = $row_postingan['post_text'];
$postingan_array['image']=array();
$postingan_array['comment']=array();

$fetch_images = mysqli_query($mysqli, "SELECT id_picture, picture_name FROM attach_picture WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($mysqli));
while ($row_image = mysqli_fetch_assoc($fetch_images)) {
    $image_array['id']=$fetch_images['id_picture'];
    $image_array['pict']=$fetch_images['picture_name'];
    array_push($postingan_array['image'], $image_array);
}
$fetch_comments = mysqli_query($mysqli, "SELECT id_comment, comment_text FROM comment_table WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($mysqli));
while ($row_comment = mysqli_fetch_assoc($fetch_comments)) {
    $comment_array['id']=$fetch_comments['id_comment'];
    $comment_array['comment']=$fetch_comments['comment_text'];
    array_push($postingan_array['comment'], $comment_array);
}
array_push($postinganlist_array, $postingan_array);}
$jsonData = json_encode(($postinganlist_array));
echo $jsonData;
?>

输出就像

success
Warning: mysqli_query(): Couldn't fetch mysqli in C:\xampp\htdocs\post\get.php on line 36 

Warning: mysqli_error(): Couldn't fetch mysqli in C:\xampp\htdocs\post\get.php on line 37 

第36行:(&#34; SELECT id_post,post_text FROM post_table&#34;)
第37行:(或死(mysqli_error($ mysqli));

我的预期结果就像

[{
    "id": "1",
    "text": "Good morning all",
    "image": 
    {
        "id": "1",
        "pict": "morning.jpg"
    }
    "comment": [
    {
        "id": "1",
        "comment": "Nice picture"
    }
    {
        "id": "2",
        "comment": "Thank you"
    }
    ]

    "id": "2",
    "text": "This is my new project",
    "image": [
        {
            "id": "2",
            "pict": "splassreen.jpg"
        }
        {
            "id": "3",
            "pict": "main.jpg"
        }
    ]
    "comment": [
        {
            "id": "3",
            "comment": "Great app"
        }
        {
            "id": "4",
            "comment": "Amazing"
        }
    ]
}
]

帮我解决问题

1 个答案:

答案 0 :(得分:1)

在您使用的code

$con = mysqli_connect('localhost', 'root', '', 'postingan');

$fetch_postingan = mysqli_query($mysqli, "SELECT id_post, post_text FROM post_table") or die(mysqli_error($mysqli));

$fetch_images = mysqli_query($mysqli, "SELECT id_picture, picture_name FROM attach_picture WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($mysqli));

$fetch_comments = mysqli_query($mysqli, "SELECT id_comment, comment_text FROM comment_table WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($mysqli));

mysqli_query使用connection string。您输入的$mysqli应该是$con。您的查询必须如下:

$fetch_postingan = mysqli_query($con, "SELECT id_post, post_text FROM post_table") or die(mysqli_error($con));

$fetch_images = mysqli_query($con, "SELECT id_picture, picture_name FROM attach_picture WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($con));

$fetch_comments = mysqli_query($con, "SELECT id_comment, comment_text FROM comment_table WHERE id_post = ".$row_postingan['id_post']."") or die(mysqli_error($con));