dudu-java

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
    ;    

发表于 2016-05-25 11:45  dudu_java  阅读(14606)  评论(0编辑  收藏  举报
 

分类:

技术点:

相关文章:

  • 2021-11-28
  • 2022-01-22
  • 2022-12-23
  • 2021-12-12
  • 2022-12-23
  • 2021-12-12
  • 2021-09-21
猜你喜欢
  • 2021-11-28
  • 2021-11-28
  • 2021-11-28
  • 2021-07-04
  • 2021-12-07
  • 2021-11-28
相关资源
相似解决方案