oracle sys_connect_by_path实现行列转换

本文讨论了在Oracle数据库版本不足10g时,如何解决无法使用wm_concat函数进行特定操作的问题,并提供了两种解决方案,包括使用sys_connect_by_path和wm_concat函数的10g实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//原帖:http://topic.youkuaiyun.com/u/20110412/16/3eec4221-d1f7-4cd2-95d0-27f3ff086632.html?77362 //前几天,一优快云友友问了一个行列转换的问题。 //问题之后的几分钟之内,好多优快云友友都给出了正确答案。 //但是,这位兄弟的一句话让大家很是郁闷: //"诺诺的答谢 楼上各位大大。。。只是纠结的说下:oracle版本没到10g。。。没有wm_concat" //wm_concat函数是10g才引入的。 //哎!真是一个杯具,提问时怎么不将oracle版本号贴出来呢? //等了2天,终于,一位大虾来将此问题解决了,下面是代码: with tb as( select 'A' grade,'XX'name from dual union all select 'A','XY' from dual union all select 'A','YY' from dual union all select 'B','aa' from dual union all select 'B','bb' from dual) select grade,substr(max(sys_connect_by_path(name,';')),2) name from (select grade,name,row_number() over(partition by grade order by name) rn from tb) start with rn=1 connect by rn= prior rn+1 and connect_by_root(grade)=grade group by grade; -- GRADE NAME ----- -------------------------------------------------------------------------------- A XX;XY;YY B aa;bb -- 10g的实现: with t as( select 'A' grade,'XX'name from dual union all select 'A','XY' from dual union all select 'A','YY' from dual union all select 'B','aa' from dual union all select 'B','bb' from dual) select grade,wmsys.wm_concat(name) name from t group by grade; -- GRADE NAME ----- -------------------------------------------------------------------------------- A XX,XY,YY B aa,bb

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值