0

我有以下表格:

+---------+-----------+      +----------+---------+-------------+
| item_id | item_name |      | image_id | item_id |  image_url  |
+---------+-----------+      +----------+---------+-------------+
|       1 | phone     |      |        1 |       1 | http://url1 |
|       2 | computer  |      |        2 |       1 | http://url2 |
|       3 | keyboard  |      |        3 |       2 | http://url2 |
+---------+-----------+      +----------+---------+-------------+

我应该在 php 中使用 PDO 和 json 编码做什么以获得以下输出:

[
    {
        "item_id":"1",
        "name":"phone",
        "images": [
            {
                "image_id":"1",
                "url":"http://url1"
            },
            {
                "image_id":"2",
                "url":"http://url2"
            }
        ]
    },
    {
        "item_id":"2",
        "name":"computer",
        "images": [
            {
                "image_id":"3",
                "url":"http://url3"
            }
        ]
    },
    {
        "item_id":"3",
        "name":"keyboard",
        "images": []
    }
]

我必须在foreach循环中使用foreach来获得这个结果吗?

4

1 回答 1

0

不,使用单个循环和单个 SQL 查询。

首先,SQL查询是

SELECT im.image_id, im.image_url, im.item_id
       it.item_name
FROM images im 
   LEFT JOIN items it ON it.item_id=im.item_id
ORDER BY im.item_id, im.image_id

而您的 PHP(意译)是:

$lastItemId = -1;
$aJson = array();
while ($row = GetNextRow()) {    // Depends on your class
    $itemID = $row['item_id'];
    if (!isset($aJson[$itemID])) {
        $aJson[$itemID] = array('item_id'=$itemID, 'item_name'=$row['item_name'], images=>array());
    }
    $aJson[$itemID]['images'] = array('image_id'=>$row['image_id'], 'image_url'=>$row['image_url']);

}
echo json_encode($aJson);

您应该可以从那里进行调整?

于 2012-08-14T04:46:35.630 回答