Oracle函数--字符串拼接
常⽤的字符串聚合(拼接)函数介绍
1.WMSYS.WM_CONCAT
从oracle 10G开始⽀持,使⽤案例如下:
select deptno,wmsys.wm_concat(ename)
from emp
group by deptno;
若想将字符之间的分隔符换成其他标点,可添加⼀个replace函数
select deptno,replace(wmsys.wm_concat(ename),',','、')
from emp
group by deptno;
2.LISTAGG(measure_expr,delimiter) WITHIN GROUP(order_by_clause) OVER(query_partition_clause)
从oracle 11G R2开始⽀持,可以⾃⼰指定分隔符,拼接的字符串可以按照某列排序,使⽤案例如下:
select deptno,Listagg(ename, '、') Within Group (Order by sal)
from emp
group by deptno;
3.SYS_CONNECT_BY_PATH
从oracle 9i开始⽀持,有2个参数,第⼀个参数是形成树形式的字段,第⼆个参数是⽗级和其⼦级分隔显⽰⽤的分隔符,该函数适⽤于有⽗⼦关系的树形结构显⽰,使⽤案例如下:
select MAX(deptno),max(substr(sys_connect_by_path(ename,'-'),2))
from emp
where deptno=10
start with ename='KING'
connect by prior empno=mgr
字符串replace函数;
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论