使用SQLServerCTE递归查询处理树、图和层次

使用SQLServerCTE递归查询处理树、图和层次
CTE(公用表表达式)可以从SQL Server 2005的版本。指定的临时命名的结果集,即CTE。类似于一个派生表,它不存储为一个对象,并且是有效的只有在查询。不像派生表,CTE可以自我参照,也可以在同一查询中引用了很多次。使用CTE可以提高代码的可读性,而不损害其性能

递归CTE是SQL Server 2005中最重要的增强之一,一般来说,在处理树、图和层次结构中的问题时,我们需要使用递归查询。
CTE的语法如下所示

与热膨胀系数为

选择工号,ReportTo FName,从雇用,工号=
联盟的所有
选择emp.empid,emp.reportto,emp.fname从CTE加入雇用的工号= emp.reportto EMP对CTE。


递归CTE中至少含有两种查询(也被称为成员)。第一个查询是一个定点的成员,和定点成员只查询返回一个有效的表,它是用于递归的基础或位置。二查询称为递归成员,以便查询被称为一个递归成员,这是一个递归引用CTE名称引发的。从逻辑上讲,名字的CTE内部应用可以理解为以前的查询结果集。
递归查询没有显式递归终止条件。只有当二递归查询返回空结果集或超过递归次数的最大限制,他们停止递归的方法是递归的上限是maxrecurion使用。

使用AdventureWorks;

——创建一个无限循环
与热膨胀系数(EmployeeID、managerid,作为标题)

选择EmployeeID、managerid,标题
从员工的人力资源。
在managerid不空
联盟的所有
选择cte.employeeid,cte.managerid,CTE名称。
从热膨胀系数
加入人力资源员工为E。
在cte.managerid = e.employeeid

-使用maxrecursion限制递归级别
选择EmployeeID、managerid,标题
从热膨胀系数
期权(maxrecursion);
以上内容是本文介绍SQLServer CTE递归查询处理树的使用,结构图和层次,我希望你喜欢它。
免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部