oracle中的listagg函数
(2013-12-09 14:58:44)
标签:
sqlit |
分类: sql |
最基础的用法:
LISTAGG(XXX,XXX) WITHIN GROUP( ORDER BY XXX)
用法就像聚合函数一样,通过Group by语句,把每个Group的一个字段,拼接起来。
心得:LISTAGG()把它当作SUM()函数来使用就可以了。
表:user
id
1
2
3
4
5
6
7
select grade, listagg(name,';') as username within group(order by grade) from user group by grade;
结果:
grade
1
2
3
同样是聚合函数,还有一个高级用法:
就是over(partition by XXX)
也就是说,在你不实用Group by语句时候,也可以使用LISTAGG函数:
select id,name,grade, listagg(name,';') as username within group(order by grade) over (partition by grade) as username from user;
结果:
id name grade username
1
2
3
4
5
6
7