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表示没有次数限制.
相关文章
- milvus k8s部署后一键查看节点日志
- ROS机器人程序设计(原书第2版)2.4.9 创建节点
- pbs集群 计算节点采用Infiniband互联
- Zookeeper常用节点命令
- 基于Docker快速搭建多节点Hadoop集群--已验证
- 浅析浏览器的5种ObserverAPI的应用:IntersectionObserver元素可见性监听、MutationObserver元素的属性或子节点变化监听、ResizeObserver元素大小变化监听、PerformanceObserver监听Performance行为记录、ReportingObserver监听过时api或浏览器自身干预行为
- 关于Cocos2d-x节点和精灵节点的坐标、位置以及大小的设置
- Sql Server 取xml中节点值
- 【大数据】YARN节点标签Node Label特性