Oracle递归查询,Oracle START WITH……CONNECT BY查询,Oracle树查询

================================

©Copyright 蕃薯耀 2018年5月14日

https://www.cnblogs.com/fanshuyao/

说明:

现在表(CMM_CODE)中有一批树结构的数据,主键为CODE_ID,以字段PARENT_CODE_ID作为父结构关联,最顶层结构的PARENT_CODE_ID为空,数据结构例子如下:

  1. 专业设施名称 > 公共服务设施 > 特殊设施

现在要根据CODE_ID查询出完整的树结构名称,通过大于号(>)拼接起来,如上面所示。

一、方法一:使用START WITH……CONNECT BY查询,再使用SYS_CONNECT_BY_PATH拼接

  1. SELECT CC.*,SUBSTR(SYS_CONNECT_BY_PATH(CC.CODE_NAME, '>'),2) TREE_PATH
  2. FROM CMM_CODE CC
  3. START WITH CC.Code_Id='pn_0501004'
  4. CONNECT BY PRIOR CC.PARENT_CODE_ID= CC.CODE_ID --此处PARENT_CODE_ID和CODE_ID顺序受PRIOR影响
  5. ;

SYS_CONNECT_BY_PATH : 和父结构名称拼接

SUBSTR : 去除最前面的大于号(>)

CONNECT BY PRIOR :需要注意的是PRIOR 的顺序

  1. CONNECT BY PRIOR CC.PARENT_CODE_ID= CC.CODE_ID

  1. CONNECT BY CC.PARENT_CODE_ID= PRIOR  CC.CODE_ID

查询出来的数据是不一样。

上面sql查询结果如下:


 

 查询出来的数据为3条是对的,但查询出来的数据不能再进行第二次的过滤查询,会报错,如:

  1. SELECT * FROM (
  2. SELECT CC.*,SUBSTR(SYS_CONNECT_BY_PATH(CC.CODE_NAME,     '>'),2) TREE_PATH
  3. FROM CMM_CODE CC
  4. START WITH CC.Code_Id='pn_0501004'
  5. CONNECT BY PRIOR CC.PARENT_CODE_ID= CC.CODE_ID--此处    PARENT_CODE_ID和CODE_ID顺序受PRIOR影响
  6. ) TEMP WHER TEMPCODE_ID='pn_0500000'
  7. ;

而且查询出来的结构顺序是相反的,如下:

  1. 特殊设施>公共服务设施>专业设施名称

方法二:使用WM_CONCAT函数进行拼接

  1. --TO_CHAR是为了将clob转成一般字符类型
  2. --REPLACE是将逗号(,)改成大于号(>)
  3. --WM_CONCAT字符串拼接,默认是使用逗号(,)拼接
  4. --查询结果:专业设施名称 > 公共服务设施 > 特殊设施
  5. SELECT TO_CHAR(REPLACE(WM_CONCAT(TEMP.CODE_NAME), ',', ' > ')) TREE_PATH FROM(
  6. SELECT CC.*
  7. FROM CMM_CODE CC
  8. START WITH CC.Code_Id='pn_0501004'
  9. CONNECT BY PRIOR CC.PARENT_CODE_ID=CC.CODE_ID
  10. ORDER BY CC.ORDER_NUMBER
  11. )TEMP
  12. ;

查询结果如下:

  1. 专业设施名称 > 公共服务设施 > 特殊设施

结果顺序正确,但一样是不能关联其它的表进行查询。因为START WITH 后面必须加上具体的条件,不能使用关联的的字段。

方式三:START WITH关联查询

  1. select info.*,
  2. CC.CODE_NAME,SUBSTR(TEMP_TABLE.TREE_PATH, 4) TREE_PATH
  3. from pn_place_name info
  4. LEFT JOIN CMM_CODE CC ON CC.CODE_ID=INFO.CMM_CODE_ID
  5. LEFT JOIN (
  6. SELECT code.*,SYS_CONNECT_BY_PATH(code.CODE_NAME, ' > ') TREE_PATH
  7. FROM CMM_CODE  code
  8. START WITH code.PARENT_CODE_ID IS NULL AND code.CLASS_CODE='PN_TYPE_NEW'
  9. CONNECT BY PRIOR code.CODE_ID= code.PARENT_CODE_ID
  10. ) TEMP_TABLE ON TEMP_TABLE.CODE_ID=INFO.CMM_CODE_ID
  11. where 1=1 and info.ISINSPECTOPINION is null
  12. AND info.PN_NO='106737'
  13. ;

SUBSTR(TEMP_TABLE.TREE_PATH, 4):去掉最前面的 空格 + 大于号(>)+ 空格

  1. ' > '

方法三和方法二的区别在于START WITH 后面的条件,和

CONNECT BY PRIOR code.CODE_ID= code.PARENT_CODE_ID

的条件,此处的顺序是不一样的。

方法三是把所有PARENT_CODE_ID IS NULL 的数据都取出来,即把最顶层的结构都先取出来,再去关联子结构,取出来的数据是所有的。唯一的好处是可以关联其它表进行查询。

结果:

知道具体的id值,并且是单条数据查询,不需要关联表时,使用方式二。

需要关联表查询时,使用方式三。

================================

©Copyright 蕃薯耀 2018年5月14日

https://www.cnblogs.com/fanshuyao/

Oracle递归查询,Oracle START WITH……CONNECT BY查询的更多相关文章

  1. Oracle递归查询(start with…connect by prior)

    查询基本结构: select … from table_name       start with 条件1       connect by 条件2 1.建测试用表 create table test ...

  2. Oracle 递归查询 (start with ...connect by ...prior)

    1.connect by 是结构化查询中用到的,其基本语法是:select … from tablename start with 条件1connect by 条件2where 条件3;例:selec ...

  3. Oracle递归查询start with connect by prior

    一.基本语法 connect by递归查询基本语法是: select 1 from 表格 start with ... connect by prior id = pId start with:表示以 ...

  4. 【转载】Oracle递归查询:使用prior实现树操作【本文出自叶德华博客】

    本文标题:Oracle递归查询:使用prior实现树操作 本文链接:http://yedward.net/?id=41 本文版权归作者所有,欢迎转载,转载请以文字链接的形式注明文章出处. Oracle ...

  5. Oracle学习之start with...connect by子句的用法

    转自:http://www.blogjava.net/xzclog/archive/2010/03/05/314642.html,多谢博主分享 Oracle中start with…connect by ...

  6. [转]ORACLE递归查询

    转自:http://www.oracle.com/technetwork/cn/articles/hartley-recursive-086819-zhs.html 递归数据库处理,也称为材料清单 或 ...

  7. Oracle递归查询与常用分析函数

    最近学习oracle的一些知识,发现自己sql还是很薄弱,需要继续学习,现在总结一下哈. (1)oracle递归查询  start with ... connect by prior ,至于是否向上查 ...

  8. oracle中start with和connect by的用法理解

    转自:https://blog.csdn.net/qq_29274091/article/details/72627350 Oracle中start with和connect by 用法理解转自:ht ...

  9. 【2016-11-7】【坚持学习】【Day22】【Oracle 递归查询】

    直接在oracle 递归查询语句 select * from groups start with id=:DeptId connect by prior superiorid =id 往下找 sele ...

随机推荐

  1. Redis的快照持久化-RDB与AOF

    Redis持久化功能 Redis为了内部数据的安全考虑,会把本身的数据以文件形式保存到硬盘中一份,在服务器重启之后会自动把硬盘的数据恢复到内存(redis)的里边. 数据保存到硬盘的过程就称为“持久化 ...

  2. Vue 2.3、2.4 知识点小结

    2.3 style 多重值: <div :style="{ display: ['-webkit-box', '-ms-flexbox', 'flex'] }">< ...

  3. linux下gflags的安装

    gflags是google开发的一套命令行参数解析工具,被很多软件系统所依赖,应该算是一个基础的库,安装其实很简单,但是如果在网上找的一些教程大部分都是安装后不能被其他软件调用的,因为默认使用cmak ...

  4. hibernate JPA 使用懒加载时代理对象

    hibernate延迟加载代理对象实际对象读取方式 public static <T> T deproxy (T obj) { if (obj == null) return obj; i ...

  5. 使用python实现深度神经网络 3(转)

    使用python实现深度神经网络 3 快速计算梯度的魔法--反向传播算法 快速计算梯度的魔法--反向传播算法 一.实验介绍 1.1 实验内容 第一次实验最后我们说了,我们已经学习了深度学习中的模型mo ...

  6. 让Linux系统开机速度更快的方法

    进行 Linux 内核与固件开发的时候,往往需要多次的重启,会浪费大把的时间. 在所有我拥有或使用过的电脑中,启动最快的那台是 20 世纪 80 年代的电脑.在你把手从电源键移到键盘上的时候,BASI ...

  7. SpringBoot项目接口第一次访问慢的问题

    SpringBoot的接口第一次访问都很慢,通过日志可以发现,dispatcherServlet不是一开始就加载的,有访问才开始加载的,即懒加载. 2019-01-25 15:23:46.264 IN ...

  8. PowerShe 消息提示框测试

    1. 使用powerShell 弹出一个简单的消息框,代码如下,创建test.ps1脚本文件. $ConfirmPreference = 'None' $ws = New-Object -ComObj ...

  9. mysql多实例配置下,用脚本启动mysql时,出现Please read "Security" section of the manual to find out how to run mysqld as root!

    [root@localhost 3308]# mysqld stop170414 0:35:28 [Note] --secure-file-priv is set to NULL. Operation ...

  10. Effective Java 第三版——76. 争取保持失败原子性

    Tips 书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code 注意,书中的有些代码里方法是基于Java 9 API中的,所 ...