将多行转成一行 oracle

这是一个Oracle的列转行函数:LISTAGG()

示例代码

  1. withtempas(
  2. select'China'nation,'Guangzhou'cityfromdualunionall
  3. 'Shanghai'city'Beijing'cityselect'USA'nation,'NewYork'city'Bostom'cityselect'Japan'nation,'Tokyo'cityfromdual
  4. )
  5. selectnation,listagg(city,',')withinGROUP(orderbycity)
  6. fromtemp
  7. groupbynation

这是最基础的用法

LISTAGG(XXX,XXX) WITHIN GROUP( ORDER BY XXX)

用法就像聚合函数一样,通过Group by语句,把每个Group的一个字段,拼接起来。

非常方便。

同样是聚合函数,还有一个高级用法

就是over(partition by XXX)

也就是说,在你不实用Group by语句时候,也可以使用LISTAGG函数

    select500population,'China'nation,85); font-weight:bold">select1500population,85); font-weight:bold">select1000population,'USA'nation,'Japan'nation,85); font-weight:bold">selectpopulation,
  1. nation,250)"> city,250)"> listagg(city,85); font-weight:bold">bycity)over(partitionbynation)rank
  2. temp

总结:LISTAGG()把它当作SUM()函数来使用就可以了。


转载:http://dacoolbaby.iteye.com/blog/1698957

相关文章

数据库版本:11.2.0.4 RAC(1)问题现象从EM里面可以看到,在23号早上8:45~8:55时,数据库等待会话暴增...
(一)问题背景最近在对一个大约200万行数据的表查看执行计划时,发现存在异常,理论上应该返回100多万...
(一)删除备份--DELETE命令用于删除RMAN备份记录及相应的物理文件。当使用RMAN执行备份操作时,会在RM...
(1)DRA介绍 数据恢复顾问(Data Recovery Advise)是一个诊断和修复数据库的工具,DRA能够修复数据文...
RMAN(Recovery Manager)是Oracle恢复管理器的简称,是集数据库备份(backup)、修复(restore)和恢复...
(1)备份对象 可以使用RMAN进行的备份对象如下: --整个数据库:备份所有的数据文件和控制文件; --数...