WITH递归原理

公用表表达式(CTE):common table expression

CTE支持递归查询,定义一个递归CTE至少需要两个(可能更多)查询:第一个查询称为定位点成员,第二个查询称为递归成员,基本格式如下:

WITH <CTE_NAME>[(TARGET_COLUMN_LIST)]
AS
(
<ANCHOR_MEMBER>
UNION ALL
<RECURSIVE_)MEMEBER>
)
<OUTER_QUERY_AGAINST_CTE>;

 定位点成员只是一个返回有效关系结果表的查询,与用于定义非递归表达式的查询类似,定位点成员查询只被调用一次。

下面举例理解递归原理:

以下代码演示了如何使用递归CTE来返回有关某个雇员及其所有各级下属的信息

WITH EMPSCTE AS
(
SELECT EMPID,MGRID, FIRSTNAME,LASTNAME
FROM HR.EMPLOYEES
WHERE EMPID=2
UNION ALL
SELECT C.EMPID,C.MGRID,C.FIRSTNAME,C.LASTNAME FROM
EMPSCTE AS P JOIN HR.EMPLOYEES AS C ON C.MGRID =P.EMPID
)
SELECT EMPID ,MGRID,FIRSTNAME,LASTNAME
FROM EMPSCTE;

 定位点成员对HR.employees表进行查询,只返回雇员ID等于2的雇员行:

select empid ,mgrid,firstname,lastname 
from hr.employees 
where empid=2

 递归成员查询对CTE(代表前一次递归调用的结果集)和employees表进行联接,返回在前一次递归调用的结果集中所返回雇员的直接下级:

SELECT C.EMPID,C.MGRID,C.FIRSTNAME,C.LASTNAME FROM
EMPSCTE AS P JOIN HR.EMPLOYEES AS C ON C.MGRID =P.EMPID

 换句话说,要多次重复调用递归成员,每次调用返回下一级下属,第一次调用递归成员,返回雇员2的直接下属:雇员3和雇员5.第二次调用递归成员,返回雇员3和雇员5 的直接下属:雇员4,6,7,8,9.第三次调用递归成员,没有更多地下级雇员,递归成员返回一个空的结果集,递归至此结束。

 

转载于:https://www.cnblogs.com/elevenlang/p/3490844.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值