oracle 递归查询

本文深入探讨了SQL递归查询的原理,详细解释了定点成员和递归成员的概念,以及如何通过递归查询实现子向父节点或父向子节点的数据检索。递归查询在没有显式终止条件的情况下,依赖于返回空结果集或达到递归次数上限来停止。文章还提供了具体的SQL语句示例,展示如何进行递归查询。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Sql递归原理

递归最少包括两个查询(也被称为成员)。第一个查询为定点成员,定点成员只是一个返回有效表的查询,用于递归的基础或定位点。 
第二个查询被称为递归成员,使该查询成为递归成员的是对递归引用时触发(递归表.id与该表的pid)。在逻辑上,可以将其理解为是前一个查询语句的子集。 

递归查询没有显式的递归终止条件,只有当第二个递归查询返回空结果集或是超出了递归次数的最大限制时才停止递归。递归次数上限的方法是使用MAXRECURION。

子向父节点递归

select * from table start with id=1 connect by prior pid=id

父向子节点递归(不含根节点)

select * from table start with pid=1 connect by prior id=pid

父向子节点递归(含根节点)

select * from table start with id=1 connect by prior id=pid

也可以设置条件来查询(子向父) 例如:

select * from table where id = 1 start with id=id connect by prior pid=id

也可以根据查到未知id值来查询(子向父)

select a.id ,(select * from table where id = a.id start with id=id connect by prior pid=id) as pid from table




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值