如何使用一个查询获得包含子列表的列表? [英] How can I get a list with sublists using one query?

查看:107
本文介绍了如何使用一个查询获得包含子列表的列表?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想打印数据库表中的项目列表,并与每个列表一起列出相关子项目的一小部分列表(最多10个项目).

I would like to print a list of items from a database table, and together with each one, a little list (10 items max) of related subitems.

例如,我有以下两个表:

For example, I have these 2 tables:

ITEMS

id: integer
name: string


SUBITEMS

id: integer
name: string
item_id: integer

因此,一个项目可以有很多子项目.

So, an item can have many subitems.

我想打印这样的东西:

Item 1
this item has: subitem 1, subitem 2, subitem 3

Item 2
this item has: subitem 4, subitem 5, subitem 6

Item 3
this item has: subitem 2, subitem 4, subitem 7

如何在SQL中完成此操作?这有可能吗?

How can this be done in SQL? Is this even possible?

推荐答案

如果是MySQL,则

select i.*, group_concat(si.name) as subitems
from items i
left join subitems si on si.item_id = i.id
group by i.id

这篇关于如何使用一个查询获得包含子列表的列表?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆