DB2递归SQL

本文详细解析了DB2中递归SQL的实现方法,通过公共表达式(CTE)展示如何构建递归查询,包括初始查询、递归查询及终止条件的设置,适用于数据库设计与查询优化的学习。

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

转载地址:https://blog.youkuaiyun.com/tianlincao/article/details/7258383

转载说明:只是为了学习,如有冒犯,会随时删除。

递归sql在DB2中通过公共表达式 (CTE,Common Table Expression) 来实现。递归sql由递归CTE及对递归CTE结果的查询组成。如果CTE中的FULLSELET在FROM子句中应用到CTE本身,就是递归CTE。递归CTE包含以下但部分:

1.初始查询

初始查询是CTE中对基本表进行查询的部分,CTE 定义中的第一个 FULLSELECT 必须不包含对 CTE 自身的应用,即必须是初始查询。

2.递归查询
递归查询就是通过对 CTE 自身的引用,从而启动递归逻辑的查询。递归查询需要遵循以下几个规则 :
递归查询和初始查询结果必须包含相同数量的数据列;
递归查询和初始查询结果数据列的、长度等必须一致;
递归查询不能包含 GROUP BY 或者 HAVING 子句;
递归查询不能包含 Outer Join;
递归查询不能包含子查询 (Subquery);
递归查询必须用 UNION ALL 联结。
3.终止条件
终止条件通常是隐性的,即如果前一次递归查询返回的结果集为空,则终止递归;但是也可以在递归查询中设定终止条件,如限定递归查询的深度等。

WITH  corp (corpid, corpname, parentcorpid,corpstate) AS (  SELECT

corp1.corpid,corp1.corpname, corp1.parentcorpid,corp1.corpstate FROM t_corpinfo corp1 where

corp1.corpid='null' 

UNION ALL  

SELECT CHILD.corpid, CHILD.corpname, CHILD.parentcorpid, CHILD.corpstate FROM corp PARENT,

t_corpinfo CHILD WHERE PARENT.corpid= CHILD.parentcorpid ) 

 select corp.corpidfrom corp where corp.corpstate = '0' 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值