Oracle 列转行函数 Listagg()
* 博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。
* 如有侵权,马上联系我,我立马删除对应链接。
* @author Alan
* @Email no008@foxmail.com
本文来源于:dacoolbaby 的 <Oracle 列转行函数 Listagg()>
这是一个Oracle的列转行函数:LISTAGG()

1 with temp as( 2 select 'China' nation ,'Guangzhou' city from dual union all 3 select 'China' nation ,'Shanghai' city from dual union all 4 select 'China' nation ,'Beijing' city from dual union all 5 select 'USA' nation ,'New York' city from dual union all 6 select 'USA' nation ,'Bostom' city from dual union all 7 select 'Japan' nation ,'Tokyo' city from dual 8 ) 9 select nation,listagg(city,',') within GROUP (order by city) 10 from temp 11 group by nation
这是最基础的用法:
LISTAGG(XXX,XXX) WITHIN GROUP( ORDER BY XXX)
用法就像聚合函数一样,通过Group by语句,把每个Group的一个字段,拼接起来。
非常方便。
同样是聚合函数,还有一个高级用法:
就是over(partition by XXX)
也就是说,在你不实用Group by语句时候,也可以使用LISTAGG函数:

1 with temp as( 2 select 500 population, 'China' nation ,'Guangzhou' city from dual union all 3 select 1500 population, 'China' nation ,'Shanghai' city from dual union all 4 select 500 population, 'China' nation ,'Beijing' city from dual union all 5 select 1000 population, 'USA' nation ,'New York' city from dual union all 6 select 500 population, 'USA' nation ,'Bostom' city from dual union all 7 select 500 population, 'Japan' nation ,'Tokyo' city from dual 8 ) 9 select population, 10 nation, 11 city, 12 listagg(city,',') within GROUP (order by city) over (partition by nation) rank 13 from temp
总结:LISTAGG()把它当作SUM()函数来使用就可以了。
学问:纸上得来终觉浅,绝知此事要躬行
为事:工欲善其事,必先利其器。
态度:道阻且长,行则将至;行而不辍,未来可期
.....................................................................
------- 桃之夭夭,灼灼其华。之子于归,宜其室家。 ---------------
------- 桃之夭夭,有蕡其实。之子于归,宜其家室。 ---------------
------- 桃之夭夭,其叶蓁蓁。之子于归,宜其家人。 ---------------
=====================================================================
* 博客文章部分截图及内容来自于学习的书本及相应培训课程以及网络其他博客,仅做学习讨论之用,不做商业用途。
* 如有侵权,马上联系我,我立马删除对应链接。 * @author Alan -liu * @Email no008@foxmail.com
转载请标注出处! ✧*꧁一品堂.技术学习笔记꧂*✧. ---> https://www.cnblogs.com/ios9/
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?