oracle合并逗号分隔,如何在Oracle中将多行合并为逗号分隔的列表?

bd31edddffe7308071c39d5410afe4da.png

潇湘沐

这里有一个简单的方法,不需要strgg或创建函数。create table countries ( country_name varchar2 (100));insert into countries values ('Albania');insert into countries values ('Andorra');insert into countries values ('Antigua');SELECT SUBSTR (SYS_CONNECT_BY_PATH (country_name , ','), 2) csv      FROM (SELECT country_name , ROW_NUMBER () OVER (ORDER BY country_name ) rn,

                   COUNT (*) OVER () cnt              FROM countries)

     WHERE rn = cntSTART WITH rn = 1CONNECT BY rn = PRIOR rn + 1;CSV                                                                             

--------------------------Albania,Andorra,Antigua                                                         

1 row selected.正如其他人所提到的,如果您在11gR2或更高的位置,现在可以使用listagg,这要简单得多。select listagg(country_name,', ') within group(order by country_name) csv  from countries;CSV                                                                             

--------------------------Albania, Andorra, Antigua1 row selected.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值