ORACLE SUBSTR函数和INSTR函数的结合

ORACLE SUBSTR函数和INSTR函数的结合

编写脚本时,经常会用到SUBSTR函数和INSTR函数结合使用,往往会出现"意想不到"的效果,这里不再介绍SUBSTR函数和INSTR函数的用法,主要讲下个人在实际开发中的案例供大家参考.
前景:
现有按照树形结构存储在ORACLE数据库中的一组组织结构数据,例如:
一级部门-二级部门-三级部门
需求:
需截取数据,例如:二级部门-三级部门
技术引用:
Oracle函数sys_connect_by_path
语法:
Oracle函数:sys_connect_by_path 主要用于树查询(层次查询) 以及 多列转行。其语法一般为:
select … sys_connect_by_path(column_name,‘connect_symbol’) from table
start with … connect by … prior
理解:
对于数据库来说,根节点并不一定是在数据库中设计的顶级节点,而是start with开始的地方。sys_connect_by_path函数就是从start with开始的地方开始遍历,并记下其遍历到的节点,start with开始的地方被视为根节点,将遍历到的路径根据函数中的分隔符,组成一个新的字符串。sys_connect_by_path函数用connect by来寻找下一条记录,直到迭代找不到相应记录为止。概念与递归类似,connect by指定递归(连接)条件,如果条件不满足则递归结束。
代码:
截取之前:

SELECT SYS_CONNECT_BY_PATH(T.ORG_NAME, '-') ORG_NAME_FULL_PATH
          FROM ORG T
         WHERE 1 = 1
           AND T.IS_STOP_USED = '1'
         START WITH T.PARENT_TYPE = '0'
        CONNECT BY T.PARENT_TYPE = PRIOR T.ORG_ID

结果集:
在这里插入图片描述
截取之后:

SELECT SUBSTR(P.ORG_NAME_FULL_PATH,
              INSTR(P.ORG_NAME_FULL_PATH, '-', 2) + 1) NAME
  FROM (SELECT SYS_CONNECT_BY_PATH(T.ORG_NAME, '-') ORG_NAME_FULL_PATH
          FROM ORG T
         WHERE 1 = 1
           AND T.IS_STOP_USED = '1'
         START WITH T.PARENT_TYPE = '0'
        CONNECT BY T.PARENT_TYPE = PRIOR T.ORG_ID) P

结果集:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_37980551/article/details/89388817