转载地址: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'