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递归查询处理树的使用,结构图和层次,我希望你喜欢它。