关于wmsys.wm_concat() 多条记录合并,及可能出现的异常ORA-31061:XDB错误:special char to escaped char conversion failed

在开发过程中会遇到合并记录的情况,一般使用wmsys.wm_concat()即可,例如:

select zf_bh,wmsys.wm_concat(shgx) NO_SHGX from (select shgx from T_YZGL_DK_SHGX  where zf_bh is not null) group by zf_bh

但是wmsys.wm_concat()使用是有前提的,那就是合并后的字符串长度不能大于4000,大于4000后就出现长度超过系统限制的异常;

这时可以使用XMLAGG(XMLELEMENT(E, field || '\n')).EXTRACT('//text()').getclobval();这里‘\n’为换行符作为连接符号,也可以用其它的例如‘,’;这样就能解决问题。

select zf_bh,XMLAGG(XMLELEMENT(E, shgx || '\n')).EXTRACT('//text()').getclobval() NO_SHGX from (select shgx from T_YZGL_DK_SHGX  where zf_bh is not null) group by zf_bh

但是今天在实际开发过程中居然出现了ORA-31061:XDB错误:special char to escaped char conversion failed,有点莫名其妙啊,说特殊字符转义失败;最后再oracle官网找到了解决办法,将sql修改为:

select zf_bh,XMLAGG(XMLELEMENT(E,REGEXP_REPLACE(shgx,'[[:cntrl:]]'),'\n') ORDER BY CAST(shgx AS varchar2(4000))).EXTRACT('//text()').getclobval() NO_SHGX from (select shgx from T_YZGL_DK_SHGX  where zf_bh is not null) group by zf_bh

参考https://community.oracle.com/message/14248976

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值