0

如果我有两个简单的表:

相片 :

photoid | filename            | albumid
1       | something.jpg       |    1
2       | somethingelse.jpg   |    1

还有一张专辑表:

  albumid   | album_name        | owner_id
    1       | My Holiday 2012   |    1
    2       | My Holiday 2013   |    6

我想获取给定所有相册中包含的所有照片owner_id

我可以执行以下操作:

select albums.*, photos.*
from photo_albums as albums
left join photos as photos
on albums.albumid = photos.albumid
where albums.owner_id = :owner_id

这将为每张照片以及相关的相册数据返回 2 行。

但是,我想做的是仅返回每张专辑的行。照片行嵌套在每个相册行中。

返回类似于以下内容的输出:

[{
    albumid : 1,
    album_name : My Holiday 2012,
    owner_id : 1,
    photos : {
                 photoid : 1,
                 filename : something.jpg
             },
             {
                 photoid : 2,
                 filename : somethingelse.jpg
             }   
}]

在 MySQL 查询本身中是否有一种简单有效的方法来执行此操作?如果有怎么办?或者,我是否更好地从原始查询中获取完整的行数据,并通过循环遍历 php 中的行来将数据构造到这个输出中?

提前致谢

4

1 回答 1

1

你只是不能通过修改 SQL 查询来做到这一点。

我看到了两种实现目标的方法:

  1. 后处理您的输出以构建所需的数组结构。
  2. 使用ORM(对象关系映射)将查询结果自动映射到对象。例如,参见教义
于 2013-04-09T17:48:39.377 回答