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
相关推荐
不羁。。1 小时前
【撸靶笔记】第七关:GET - Dump into outfile - String
数据库·笔记·oracle
yangchanghua1113 小时前
pgsql 如何查询今天范围内的数据(当天0点0分0秒 - 当天23点59分59秒....)
数据库·pgsql
larance3 小时前
SQLAlchemy 的异步操作来批量保存对象列表
数据库·python
python_chai3 小时前
从数据汇总到高级分析,SQL 查询进阶实战(下篇)—— 分组、子查询与窗口函数全攻略
数据库·sql·mysql
在努力的前端小白3 小时前
Spring Boot 敏感词过滤组件实现:基于DFA算法的高效敏感词检测与替换
java·数据库·spring boot·文本处理·敏感词过滤·dfa算法·组件开发
未来之窗软件服务3 小时前
自建知识库,向量数据库 (九)之 量化前奏分词服务——仙盟创梦IDE
数据库·仙盟创梦ide·东方仙盟·自建ai·ai分词
冒泡的肥皂7 小时前
MVCC初学demo(一
数据库·后端·mysql
.Shu.8 小时前
Redis Reactor 模型详解【基本架构、事件循环机制、结合源码详细追踪读写请求从客户端连接到命令执行的完整流程】
数据库·redis·架构
薛晓刚10 小时前
当MySQL的int不够用了
数据库
SelectDB技术团队11 小时前
Apache Doris 在菜鸟的大规模湖仓业务场景落地实践
数据库·数据仓库·数据分析·apache doris·菜鸟技术