oracle 多行合一 wm_concat 函数

wmsys.wm_concat函数,它的作用是以','链接字符  (版本10G以上)


例子如下:

创建表:

create table idtable (id number,name varchar2(30));

准备数据: (共六条)

insert into idtable values(10,'ab'); 
insert into idtable values(10,'bc');
insert into idtable values(10,'cd'); 
insert into idtable values(20,'hi'); 
insert into idtable values(20,'ij');
insert into idtable values(20,'mn');

检查数据:

select * from idtable;

结果:

        ID NAME
---------- ------------------------------
        10 ab
        10 bc
        10 cd
        20 hi
        20 ij
        20 mn 

开始实验:

>ps<  这里是 order by

1:

select id,wmsys.wm_concat(name) name from idtable group by id

结果:

        ID NAME
---------- ---------------------------------------------------
        10 ab,bc,cd
        20 hi,ij,mn 

2:

select id,wmsys.wm_concat(name) over (order by id) name from idtable; 

结果:

         ID NAME
---------- ---------------------------------------------------
        10 ab,bc,cd
        10 ab,bc,cd
        10 ab,bc,cd
        20 ab,bc,cd,hi,ij,mn
        20 ab,bc,cd,hi,ij,mn
        20 ab,bc,cd,hi,ij,mn 

3:

select id,wmsys.wm_concat(name) over (order by id,name) name from idtable; 

结果:

        ID NAME
---------- ------------------------------------------------
        10 ab
        10 ab,bc
        10 ab,bc,cd
        20 ab,bc,cd,hi
        20 ab,bc,cd,hi,ij
        20 ab,bc,cd,hi,ij,mn 


>ps<   这里是 partition by
4:

select id,wmsys.wm_concat(name) over (partition by id) name from idtable;

结果:

         ID NAME
---------- -----------------------------------------------
        10 ab,bc,cd
        10 ab,bc,cd
        10 ab,bc,cd
        20 hi,ij,mn
        20 hi,ij,mn
        20 hi,ij,mn 

5:

select id,wmsys.wm_concat(name) over (partition by id,name) name from idtable; 

结果:

        ID NAME
---------- ------------------------------------------------
        10 ab
        10 bc
        10 cd
        20 hi
        20 ij
        20 mn 









 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

_yuki_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值