将多行转成一行 oracle

前端之家收集整理的这篇文章主要介绍了将多行转成一行 oracle前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

示例代码

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

这是最基础的用法

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,@H_502_24@
  1. nation,250)"> city,250)"> listagg(city,85); font-weight:bold">bycity)over(partitionbynation)rank@H_502_24@
  2. temp@H_502_24@

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


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

猜你在找的Oracle相关文章