首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用于从每列的分组记录中获取不同值的SQL查询

用于从每列的分组记录中获取不同值的SQL查询
EN

Stack Overflow用户
提问于 2020-05-20 18:42:31
回答 1查看 17关注 0票数 0

假设我有一个歌曲表

代码语言:javascript
复制
Table name: Songs
- id
- artist
- composer
- lyricist

我想编写一个sql查询,这样我就可以从按id分组的记录中获得不同的值。示例:

代码语言:javascript
复制
Id Artist Composer Lyricist
1  a1      c1       l1
1  a2      c1       l1
1  a1      c2       l1
2  a3      c1       l2
2  a4      c1       l3

查询应返回

代码语言:javascript
复制
Id Artist Composer Lyricist
1  a1, a2  c1, c2   l1
2  a3, a4  c1       l2, l3

如果我能得到一个通用的SQL查询,也就是说,不是特定于某些数据库功能,那就太好了。请注意,不同的表中的列可能不同,所以如果我不需要在查询中写每个列名就更好了。

如果有人能给我提点建议,请告诉我。

EN

回答 1

Stack Overflow用户

发布于 2020-05-20 18:44:32

Postgres SQL版本使用string_agg()array_agg()

代码语言:javascript
复制
select id,
       string_agg(distinct artist, ','),
       string_agg(distinct composer, ','),
       string_agg(distinct lyricist, ',')
from t
group by id;

一般的SQL版本称为listagg()

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61911060

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档