一对多查询
One-to-many query
我有一个假设的数据库,如下图所示,每种植物最多可以有 4 种颜色。
我希望能够 return 我的结果采用类似于下面的格式。
如果我 运行 使用内部连接的标准查询,如果植物有不止一种颜色,结果会重复。因此,我尝试了 运行 多个单独的查询,首先是 return 植物,然后是 return 颜色的新查询。然后我遍历颜色结果以产生我想要的输出。
我想还有很长的路要走?
我正在尝试将其作为查询和存储过程来执行,因此将不胜感激。
如果你知道最多有4种颜色,那么你可以使用row_number()
和条件聚合:
select plantname,
max(case when seqnum = 1 then colorname end) as color_1,
max(case when seqnum = 2 then colorname end) as color_2,
max(case when seqnum = 3 then colorname end) as color_3,
max(case when seqnum = 4 then colorname end) as color_4
from (select p.plantname, p.plantid, c.colorname,
row_number() over (partition by p.plantid order by c.colorid) as seqnum
from plants p join
plantcolors pc
on pc.plantid = p.plantid join
colors c
on pc.colorid = c.colorid
) pc
group by plantname, plantid;
我有一个假设的数据库,如下图所示,每种植物最多可以有 4 种颜色。
我希望能够 return 我的结果采用类似于下面的格式。
如果我 运行 使用内部连接的标准查询,如果植物有不止一种颜色,结果会重复。因此,我尝试了 运行 多个单独的查询,首先是 return 植物,然后是 return 颜色的新查询。然后我遍历颜色结果以产生我想要的输出。
我想还有很长的路要走?
我正在尝试将其作为查询和存储过程来执行,因此将不胜感激。
如果你知道最多有4种颜色,那么你可以使用row_number()
和条件聚合:
select plantname,
max(case when seqnum = 1 then colorname end) as color_1,
max(case when seqnum = 2 then colorname end) as color_2,
max(case when seqnum = 3 then colorname end) as color_3,
max(case when seqnum = 4 then colorname end) as color_4
from (select p.plantname, p.plantid, c.colorname,
row_number() over (partition by p.plantid order by c.colorid) as seqnum
from plants p join
plantcolors pc
on pc.plantid = p.plantid join
colors c
on pc.colorid = c.colorid
) pc
group by plantname, plantid;