oracle中分组函数LISTAGG

前言

Oracle中的 GROUP_CONCAT 函数用于将多行数据合并为一行,并以指定的分隔符分隔各个值。在Oracle中,没有直接的GROUP_CONCAT函数,但可以使用 LISTAGG 函数来实现类似的功能。

如何使用

1、使用SELECT语句选择需要合并的列,并使用LISTAGG函数进行合并。

举例:有一个名为"table_name"的表,其中包含列"column1"和"column2",我们想要将"column1"的值合并为一行,以逗号作为分隔符。

javascript 复制代码
SELECT LISTAGG(column1, ',') WITHIN GROUP (ORDER BY column1) AS concatenated_values

FROM table_name;

这将返回一个名为"concatenated_values"的列,其中包含合并后的值。

WITHIN GROUP (ORDER BY column1) 是按照 column1 字段进行排序

2、 如果需要在合并的值之间添加其他文本或字符,可以在LISTAGG函数中使用字符串连接操作符"||"。

javascript 复制代码
SELECT '(' || LISTAGG(column1, ',') WITHIN GROUP (ORDER BY column1) || ')' AS concatenated_values

FROM table_name;

显示结果: (1,2,3,4)

这将在合并的值之前和之后添加括号。

3、 存在 group by 分组的sql语句,碰到需要分组后的字段进行合并显示,则可以完美实现。

javascript 复制代码
SELECT '(' || LISTAGG(column1, ',') WITHIN GROUP (ORDER BY column1) || ')' AS concatenated_values 
FROM table_name;
GROUP BY column1
相关推荐
NineData3 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData8 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师10 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石14 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_1 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql