gpt4 book ai didi

sql - 根据左表中的值选择不同的行

转载 作者:行者123 更新时间:2023-11-29 12:39:05 24 4
gpt4 key购买 nike

使用 Postgres。这是我的场景:

我有三个不同的表。一个是标题表。第二个是流派表。第三张表用于连接两者。当我设计数据库时,我希望每个标题都有一个顶级类型。用数据填充后,我发现有些标题有两种,有时甚至三种顶级流派。

我编写了一个检索标题及其顶级流派的查询。这显然需要我加入两个表。对于那些只有一种顶级流派的唱片,只有一张唱片。对于那些有更多的,有多个记录。

我意识到我可能必须编写某种自定义函数来为我处理这个问题,但我想我会问是否有可能不这样做只是为了确保我没有丢失任何东西。

是否可以编写一个查询,让我可以选择所有不同的标题,而不管它有多少类型,但也包括类型?或者更好的是,当有多个流派时,查询会给我一个逗号分隔的流派字符串?

提前致谢!

最佳答案

听起来像是 array_agg 的工作大部头书。使用这样的表格:

create table t  (id int not null, title varchar not null);
create table g (id int not null, name varchar not null);
create table tg (t int not null, g int not null);

你可以这样做:

SELECT t.title, array_agg(g.name)
FROM t, tg, g
WHERE t.id = tg.t
AND tg.g = g.id
GROUP BY t.title, t.id

得到:

 title |       array_agg       
-------+-----------------------
one | {g-one,g-two,g-three}
three | {g-three}
two | {g-two}

然后根据需要解压数组。如果出于某种原因你真的想要一个逗号分隔的字符串而不是一个数组,那么 string_agg 是你的 friend :

SELECT t.title, string_agg(g.name, ',')
FROM t, tg, g
WHERE t.id = tg.t
AND tg.g = g.id
GROUP BY t.title, t.id

你会得到这样的东西:

 title |     string_agg      
-------+---------------------
one | g-one,g-two,g-three
three | g-three
two | g-two

我会采用数组方法,这样您就不必担心为分隔符保留字符或在聚合时必须转义(然后取消转义)分隔符。

关于sql - 根据左表中的值选择不同的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5241098/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com