Oracle函数--字符串拼接
Posted dudu_java
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
;
以上是关于Oracle函数--字符串拼接的主要内容,如果未能解决你的问题,请参考以下文章