oracle中行转列LISTAGG()函数详解及应用实例
更新时间:2024年05月27日 09:18:08 作者:sym@12
这篇文章主要给大家介绍了关于oracle中行转列LISTAGG()函数详解及应用实例的相关资料,stagg是oracle11.2增加的特性,功能类似wmsys.wm_concat函数,即将数据分组后,把指定列的数据通过指定符号合并,需要的朋友可以参考下
1.LISTAGG()函数作为普通函数使用时就是查询出来的结果列转为行


SELECT LISTAGG ( NAME_CHS, ',' ) within GROUP ( ORDER BY ROWNUM ) name FROM GSPUSER WHERE ROWNUM <= 10
2.LISTAGG()作为分组函数使用
例如,把每个班组下面的人员拼接成一行

SELECT b.MOMTEAMNAME, LISTAGG ( g.NAME_CHS, ',' ) WITHIN GROUP ( ORDER BY b.MOMTEAMNAME ) res FROM DGMOMPTDGMOMGLHQYBZGL b LEFT JOIN DGMOMPTABOUTUSERS u ON b.ID = u.PARENTID LEFT JOIN GSPUSER g ON u.MOMEMPLOYEEID = g.ID WHERE b.MOMDATASTATE = 0 AND u.MOMDATASTATE = 0 GROUP BY b.MOMTEAMNAME
3.LISTAGG()做分析函数使用
例如,查询每个班组下面有哪些人,统计每组人数量

SELECT
MOMTEAMNAME,RES,COUNT
FROM(
SELECT
b.MOMTEAMNAME,
LISTAGG ( g.NAME_CHS, ',' ) WITHIN GROUP ( ORDER BY b.MOMTEAMNAME ) over(partition by b.MOMTEAMNAME) res,
count(g.NAME_CHS) over(partition by b.MOMTEAMNAME) count,
row_number() over(partition by b.MOMTEAMNAME ORDER BY ROWNUM) rn
FROM
DGMOMPTDGMOMGLHQYBZGL b
LEFT JOIN DGMOMPTABOUTUSERS u ON b.ID = u.PARENTID
LEFT JOIN GSPUSER g ON u.MOMEMPLOYEEID = g.ID
WHERE
b.MOMDATASTATE = 0
AND u.MOMDATASTATE = 0
) WHERE rn = 1附:高级用法
listagg(XXX,’,’) within GROUP (order by XXX) over (partition by XXX) rank
示例
with temp as( select 500 population, '中国' nation ,'江苏' city from dual union all select 1500 population, '中国' nation ,'上海' city from dual union all select 500 population, '中国' nation ,'北京' city from dual union all select 1000 population, '美国' nation ,'纽约' city from dual union all select 500 population, '美国' nation ,'波士顿' city from dual union all select 500 population, '日本' nation ,'东京' city from dual ) select population, nation, city, listagg(city,',') within GROUP (order by city) over (partition by nation) rank from temp复制
运行结果

总结
到此这篇关于oracle中行转列LISTAGG()函数详解及应用实例的文章就介绍到这了,更多相关oracle行转列LISTAGG()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
如何使用GDAL库的ogr2ogr将GeoJSON数据导入到PostgreSql中
本文主要介绍了PyTorch中的masked_fill函数的基本知识和使用方法,masked_fill函数接受一个输入张量和一个布尔掩码作为主要参数,掩码的形状必须与输入张量相同,掩码操作根据掩码中的布尔值在输出张量中填充指定的值或保留输入张量中的值2024-10-10
oracle数据库删除数据Delete语句和Truncate语句的使用比较
oracle当表中的数据不需要时,则应该删除该数据并释放所占用的空间,删除表中的数据可以使用Delete语句或者Truncate语句,下面分别介绍2012-09-09
解决pl/sql developer中数据库插入数据乱码问题(SSM项目开发)
这篇文章主要介绍了解决pl/sql developer中数据库插入数据乱码问题,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2020-11-11


最新评论