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
相关推荐
ID_1800790547311 小时前
淘宝商品详情API的调用频率限制是多少?
大数据·数据库·json
2301_8042154111 小时前
Python类型提示(Type Hints)详解
jvm·数据库·python
一只努力的微服务11 小时前
【Calcite 系列】深入理解 Calcite 的 AggregateUnionTransposeRule
大数据·数据库·calcite·优化规则
2301_8166512211 小时前
用户认证与授权:使用JWT保护你的API
jvm·数据库·python
Sunshine for you11 小时前
Python单元测试(unittest)实战指南
jvm·数据库·python
研究点啥好呢11 小时前
3月28日Github热榜推荐 | 你还没有为AI接一个数据库吗
数据库·人工智能·驱动开发·github
草莓熊Lotso11 小时前
MySQL 多表连接查询实战:内连接 + 外连接
android·运维·数据库·c++·mysql
两年半的个人练习生^_^11 小时前
dynamic-datasource多数据源使用和源码讲解
java·开发语言·数据库·mybatis
倔强的石头10611 小时前
文档数据库迁移实战:MongoDB 协议级兼容与 JSONB 引擎性能深度对比
数据库·mongodb·kingbase
he___H11 小时前
mongodb
数据库·mongodb