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
相关推荐
xinyu_Jina6 分钟前
局域网文件传输:P2P应用层协议——元数据握手与数据通道的生命周期管理
数据库·asp.net·p2p
彬鸿科技23 分钟前
【SDR课堂第42讲】RFSOC开发入门之开发环境搭建(三)
linux·运维·数据库·ubuntu·postgresql·软件无线电·软无
九章-24 分钟前
金仓数据库助力中国石油安全环保技术研究院安全生产智能管控系统全面实现数据库国产化替代
数据库·安全
陌路2025 分钟前
redis 发布订阅功能
数据库·redis·缓存
丁丁丁梦涛27 分钟前
navicat跨服务器连接MySQL数据库
服务器·数据库·mysql
tgethe31 分钟前
mysql-索引详解
数据库·mysql
一个天蝎座 白勺 程序猿32 分钟前
Apache IoTDB(11):分段聚合深度解析——从原理到实战的完整指南
数据库·apache·iotdb
Java Fans36 分钟前
PyQt实现SQLite数据库操作案例详解
数据库·sqlite·pyqt
子夜江寒37 分钟前
MySQL 学习
数据库·mysql
SAP小崔说事儿1 小时前
SAP B1 库龄分析报表(SQL版本&非批次管理)
数据库·sql·sap·sap b1·business one·批次管理·库龄分析