Oracle的递归查询

语法

SELECT * from table_name start with 条件2 connect by 条件3 [where 条件1];

条件1是对结果集的再筛选。

条件2确定起始节点,可以确定多个起始节点,可以理解成查询出来的结果树的叶子节点或者根节点。

条件3是连接条件,通过关键字prior指定上一条记录。

实例

我们称表中的数据存在父子关系,通过列与列来关联的,这样的数据结构为树结构。
现在有一个menu表,字段有id,pid,title三个。

  • 查询菜单id为10的所有子菜单。
SELECT * FROM tb_menu m START WITH m.id=10 CONNECT BY m.pid=PRIOR m.id;


PRIOR关键字放在m.id前面,意思就是查询pid是当前记录id的记录,如此顺延找到所有子节点。

  • 查询菜单id为40的所有父菜单。
SELECT * FROM tb_menu m START WITH m.id=40 CONNECT BY PRIOR m.pid= m.id ORDER BY ID;


LEVEL关键字

  • 查询一个节点的父节点的的兄弟节点(伯父与叔父)
    因为创建的表没有LEVEL的字段,可以
WITH TMP AS
 (SELECT M.*, LEVEL LEV
    FROM MENU M
   START WITH M.PID = 0
  CONNECT BY PRIOR M.ID = M.PID)
SELECT * FROM TMP;


tmp的效果就是上面这样,LEV就是菜单所在的深度或者层级。

WITH TMP AS
 (SELECT M.*, LEVEL LEV
    FROM MENU M
   START WITH M.PID = 0
  CONNECT BY PRIOR M.ID = M.PID)
SELECT *
  FROM TMP
 WHERE PID =
       (SELECT PID FROM TMP WHERE ID = (SELECT PID FROM TMP WHERE ID = 21));

注意查询的不是id=20的父亲的同等级的菜单而是父亲的兄弟菜单,也就是跟父菜单具有相同pid的节点。

EXISTS和NOT EXISTS

SELECT COUNT(*)
  FROM TB_MENU M1
 WHERE EXISTS (SELECT *
          FROM TB_MENU M2
         WHERE ID = -1
           AND M1.ID = M2.ID)
   AND M1.ID = 2;

以这个查询语句为例,如果EXISTS或者NOT EXISTS后面的查询条件没有 m1.id=m2.id,其实后面的查询结果就相当于true或者false这两个值,为true,无需考虑;为false,结果为0;
加上m1.id=m2.id这一关联后,就在查询结果集里再进行一次筛选。

Oracle递归查询是一种查询技术,用于查询表的层次结构数据,例如查询某个节点的父节点或子节点。在Oracle,可以使用start with connect by prior或with递归查询来实现递归查询。 使用start with connect by prior递归查询,可以查询所有子节点、所有父节点、指定节点的根节点以及指定节点的递归路径。这种查询方法通过在查询条件使用prior关键字来指定当前数据和下一条数据之间的关系。例如,使用START WITH子句指定起始节点,然后使用CONNECT BY子句指定节点之间的关系,可以实现向上或向下递归查询。 使用with递归查询,可以通过递归调用查询多层结构的子节点或父节点。这种查询方法使用WITH子句定义递归查询的初始条件和递归关系,并使用递归子查询来实现递归查询。 需要注意的是,递归查询可能会导致查询时间特别长,特别是在数据量特别大的情况下。因此,在进行递归查询时,需要谨慎考虑查询的效率和性能。 综上所述,Oracle提供了递归查询语句来实现对层次结构数据的查询,包括start with connect by prior和with递归查询。这些查询方法可以帮助我们方便地查询父节点和子节点的关系。 #### 引用[.reference_title] - *1* [Oracle递归查询](https://blog.csdn.net/Michael_lcf/article/details/124433725)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Oracle递归查询树形数据](https://blog.csdn.net/weixin_40017062/article/details/127653569)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [ORACLE递归查询](https://blog.csdn.net/m0_46636892/article/details/122984132)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值