SQL 语句递归查询 With AS 查找所有子节点

create table #EnterPrise
(
  Department nvarchar(50),–部门名称
  ParentDept nvarchar(50),–上级部门
  DepartManage nvarchar(30)–部门经理
)

insert into #EnterPrise select ‘技术部‘,‘总经办‘,‘Tom‘
insert into #EnterPrise select ‘商务部‘,‘总经办‘,‘Jeffry‘
insert into #EnterPrise select ‘商务一部‘,‘商务部‘,‘ViVi‘
insert into #EnterPrise select ‘商务二部‘,‘商务部‘,‘Peter‘
insert into #EnterPrise select ‘程序组‘,‘技术部‘,‘GiGi‘
insert into #EnterPrise select ‘设计组‘,‘技术部‘,‘yoyo‘
insert into #EnterPrise select ‘专项组‘,‘程序组‘,‘Yue‘
insert into #EnterPrise select ‘总经办‘,‘‘,‘Boss‘

–查询部门经理是Tom的下面的部门名称
;with hgo as
(
   select *,0 as rank from #EnterPrise where DepartManage=‘Tom‘
   union all
   select h.*,h1.rank+1 from #EnterPrise h join hgo h1 on h.ParentDept=h1.Department
)
select * from hgo

/*
Department           ParentDept                DepartManage      rank
————— ——————– ———————– ———–
技术部               总经办                    Tom               0
程序组               技术部                    GiGi              1
设计组               技术部                    yoyo              1
专项组               程序组                    Yue               2
*/

–查询部门经理是GiGi的上级部门名称
;with hgo as
(
   select *,0 as rank from #EnterPrise where DepartManage=‘GiGi‘
   union all
   select h.*,h1.rank+1 from #EnterPrise h join hgo h1 on h.Department=h1.ParentDept
)
select * from hgo

/*
Department               ParentDept          DepartManage    rank
——————– ———————-  ———–  ———–
程序组                   技术部                 GiGi           0
技术部                   总经办                 Tom            1
总经办                                          Boss           2
*/

如果递归次数大于100,只需在与cte连接的sql 语句的最后加上option (maxrecursion 0) 即可.默认递归

次数为100,设为0表示没有次数限制.