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
相关推荐
Jayyih9 小时前
嵌入式系统学习Day35(sqlite3数据库)
数据库·学习·sqlite
得意霄尽欢11 小时前
Redis之底层数据结构
数据结构·数据库·redis
hsjkdhs11 小时前
MySQL 数据类型与运算符详解
数据库·mysql
爱吃烤鸡翅的酸菜鱼12 小时前
【Redis】常用数据结构之Hash篇:从常用命令到使用场景详解
数据结构·数据库·redis·后端·缓存·哈希算法
李少兄13 小时前
IntelliJ IDEA 启动项目时配置端口指南
数据库·sql·intellij-idea
NineData13 小时前
NineData云原生智能数据管理平台新功能发布|2025年8月版
数据库·mongodb·云原生·数据库管理工具·ninedata·数据库迁移·数据复制
白云如幻13 小时前
【Java】QBC检索和本地SQL检索
java·数据库·sql
勘察加熊人14 小时前
python将pdf转txt,并切割ai
数据库·python·pdf
不良人天码星14 小时前
Redis单线程模型为什么快?
数据库·redis·缓存
RestCloud15 小时前
ETL 不只是数据搬运工:如何实现智能转换与清洗?
数据库·api