1、LISTAGG() 简介函数
介绍:其函数在Oracle 11g 版本中推出,对分组后的数据按照必定的排序进行字符串链接。排序
其中,“[,]”表示字符串链接的分隔符,若是选择使用[over (partition by )]则会使其变成分析函数;字符串
用法1: SELECT aaa, listagg(bbb,',') within GROUP (ORDER BY aaa) FROM table GROUP BY aaastring
用法2: SELECT aaa, listagg(bbb,',') within GROUP (ORDER BY aaa) over(partition by aaa) FROM tableit
2、wm_concat()简介io
介绍:其函数在Oracle 10g推出,在10g版本中,返回字符串类型,在11g版本中返回clob类型。table
括号里面的参数是列,并且能够是多个列的集合,也就是说在括号里面能够自由地用‘||’合并字符串。test
用法1: Select aaa, wmsys.wm_concat(bbb || '(' || ccc || ')' ) from table group by aaaselect
用法2: Select aaa, wmsys.wm_concat(bbb || '(' || ccc || ')' ) over(partition by aaa) from table 数据
3、应用实例:
3.一、建立表 CREATE TABLE TESTAGG
(
A VARCHAR2(20),
B VARCHAR2(20),
C VARCHAR2(20)
)
3.二、初始化数据
INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B1','C1')
INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B2','C2')
INSERT INTO "TESTAGG" (A, B, C) VALUES ('1', 'B3','C3')
INSERT INTO "TESTAGG" (A, B, C) VALUES ('2', 'B4','C4')
INSERT INTO "TESTAGG" (A, B, C) VALUES ('2', 'B5','C5')
INSERT INTO "TESTAGG" (A, B, C) VALUES ('3', 'B6','C6')
3.三、wm_concat()用法
select a,wm_concat(b|| '(' || c || ')') as bc from testagg group by a order by a
1 <CLOB>--B1(C1),B2(C2),B3(C3)
2 <CLOB>--B4(C4),B5(C5)
3 <CLOB>--B6(C6)
若要转化成string能够用to_char()函数。
3.四、 LISTAGG()用法
select a,LISTAGG(b,',' ) within group(order by a) as bc from testagg group by a
1 B1,B2,B3
2 B4,B5
3 B6
注意:但当数据量比较大时,通常clob字段超过4000,却报ORA-01489:字符串链接的结果过长。有兴趣的小伙伴能够研究下解决办法。