sql 孩子兄弟表示法 所有子节点_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表示没有次数限制.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值