zoukankan      html  css  js  c++  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
        ;    

  • 相关阅读:
    软件测试作业4
    Android基础知识每日记(持续更新)
    二叉树操作总结
    No.223 Rectangle Area
    No.66 Plus One
    No.80 Remove Duplicates from Sorted Array ||
    No.27 Remove Element
    No.26 Remove Duplicates from Sorted Array
    No.9 Palindrome Number
    No.219 Contains Duplicate ||
  • 原文地址:https://www.cnblogs.com/dudu-java/p/5526442.html
Copyright © 2011-2022 走看看