oracle 聚合函数 LISTAGG ,将多行结果合并成一行
来源:互联网 发布:淘宝返现规定 编辑:程序博客网 时间:2024/06/05 11:18
LISTAGG(列名,' 分割符号')
oracle 11g 以上的版本才有的一个将指定列名的多行查询结果,用 指定的分割符号 合并成一行显示:
例如:
表原始数据:
需求:将 mb1_Transport_License_list 表中的数据,根据 transportation_license_id 数据进行分组,对 Item_Category_Name 列的数据进行 去重合并
使用聚合函数 LISTAGG 解决
SELECT transportation_license_id, LISTAGG( to_char(Item_Category_Name), ',') WITHIN GROUP(ORDER BY Item_Category_Name) AS employees FROM ( select distinct transportation_license_id, item_category_name from mb1_Transport_License_list ) group by transportation_license_id
SQL解析:
select distinct transportation_license_id, item_category_name from mb1_Transport_Lincense_list ; -- 对需要做合并处理的数据源数据进行去重处理,如果实际要求不需要去重处理,这里可以直接改为 表名,(例如: from mb1_Transport_Lincense_list)进行查询
LISTAGG( to_char(Item_Category_Name), ',') WITHIN GROUP(ORDER BY Item_Category_Name) -- 将 Item_Category_Name 列的内容以", "进行分割合并、排序;
to_char(Item_Category_Name) -- to_char(列名) 解决使用聚合函数 LISTAGG 进行查询后,对查询结果乱码问题进行转码处理;
运行后的结果:
阅读全文
0 0
- oracle 聚合函数 LISTAGG ,将多行结果合并成一行
- oracle 11g 使用listagg函数合并多行为一行
- oracle 多行合并成一行: listagg \ within group
- oracle--多行转为一行 (listagg函数)
- oracle的聚集函数wm_concat()和listagg()不适用时,自定义通用的聚集函数合并查询结果列
- oracle聚合 将多行单记录合并到一行
- WM_CONCAT LISTAGG函数,ORACLE列转行聚合的简单实现
- oracle 将多行合并成一行
- oracle中的listagg函数
- Oracle函数之LISTAGG
- oracle函数listagg()
- Oracle listagg 函数
- oracle函数listagg()
- oracle多行合并成一行自带函数
- oracle function函数合并相同列为一行
- Oracle行专列函数Listagg()
- Oracle 列转行函数 Listagg()
- Oracle 列转行函数 Listagg()
- Exchange发送邮件
- SSH连接VMware中NAT模式主机
- leetcode 1. Two Sum排序+双指针
- Python包和类的基本用法
- 2017.05.19回顾 TSS = ESS + RSS证明
- oracle 聚合函数 LISTAGG ,将多行结果合并成一行
- 【javascript】关于localstorage的使用感想
- Web应用中使用JavaMail发送邮件
- 常用SQL Server 小语法、函数 等的实例汇总
- 20个实用的webApp前端开发技巧
- UML类图关系(泛化 、实现、依赖、关联、聚合、组合)
- 一起来写一个简易的手风琴效果
- Java开发中的23种设计模式详解(转)
- win10装centos双系统之后,win10的启动项消失的解决方法