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

先看示例代码:

Sql代码

  1. withtempas(
  2. select'China'nation,'Guangzhou'cityfromdualunionall
  3. )
  4. selectnation,listagg(city,',')withinGROUP(orderbycity)
  5. fromtemp
  6. 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,

  • nation,250)"> city,250)"> listagg(city,85); font-weight:bold">bycity)over(partitionbynation)rank
  • temp
  • 总结:LISTAGG()把它当作SUM()函数来使用就可以了。

    dawei

    【声明】:淮南站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。