from @ResTab a
left join Role_CTE b on a.node=b.Id

使用 SQL CTE 实现:
declare @node int
declare @num int
set @node=8;
set @num=2;
with temp_cte
as
(
select Id,Name,ParentId,0 lv -- 查询出“根节点”,即指定的起始节点
from Role_CTE
where Id=@node
union all
select b.Id,b.Name,b.ParentId,a.lv+1
from temp_cte a
join Role_CTE b on a.ParentId=b.Id
and a.lv < @num --控制递归层数
)
select * from temp_cte
以上所述是小编给大家介绍的SQL Server 公用表表达式(CTE)实现递归的方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的,在此也非常感谢大家对软件开发网网站的支持!
您可能感兴趣的文章:使用SqlServer CTE递归查询处理树、图和层次结构使用SQLSERVER 2005/2008 递归CTE查询树型结构的方法










