星空网 > 软件开发 > 数据库

SQL Server利用递归把所有【子部门员工】汇总到【一级根节点部门】

前言

      说起这个需求,有点反常规,左边是组织机构树,右边是组织机构对应的员工列表。点击左侧组织机构时传一个组织机构ID,然后查询该组织机构以及其所属的一级节点,如果有部门直属单击节点组织机构,则挂出来员工总数,也就是说根节点不需要向下递归,只需要查询出对应的员工记录即可,相反,所以的一级节点则需要向下递归计算出所有的员工总数。刚开始只知道递归,没有具体的思路,后一个同事帮忙写了一个,后发现思路确实巧妙,所以自己拿出来再分析分享下。

 

思路分析

     1、单击根节点不需要向下递归,那么则把单击根节点单独拿出来。

     2、一级节点需要向下递归查询出其所属节点,那么首先根据ParentID查询出你传入的组织机构ID所属的一级节点组织机构(CTE递归),同时生成一个id(StartId)用来标识该组织机构隶属的组织机构,向上统计时会用到

     3、把单独拿出来的根节点和一级子节点及其所属节点用UNION ALL拼接起来,准备统计时使用。

     4、统计总数时GROUP BY 使用StartId来分组。

 

代码片段

with t as(  select * from dbo.orgInfo where pid=1 ),p as( select a.id,a.node,a.pid,a.id as StartId  from dbo.orgInfo A where id in (select t.id from t) union all select K.id,K.node,K.pid,c.StartId as StartId from dbo.orgInfo K  inner join p C on k.pid=C.id ),q as( select a.id,a.node,a.pid,A.id as StartId  from dbo.orgInfo A where id=1 union  select * from p)--select * from q select q.id,q.node,m.Total from qinner join (select q.StartId,COUNT(1) as Totalfrom qinner join dbo.userInfo a on a.OrgID=q.idgroup by q.StartId)m on q.id=m.StartId

 




原标题:SQL Server利用递归把所有【子部门员工】汇总到【一级根节点部门】

关键词:sql

sql
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

Allegro平台发什么物流,发货时效是多久?:https://www.goluckyvip.com/news/6071.html
2020春节Lazada物流安排&客服排班时间表来啦:https://www.goluckyvip.com/news/6072.html
2021年东南亚电商市场怎么样,2022年要怎么做?:https://www.goluckyvip.com/news/6073.html
虾皮Shopee铺货不是想当然,这些铺货技巧你懂吗?:https://www.goluckyvip.com/news/6074.html
进击的Shopee,2021年度APP下载量何以超过亚马逊?:https://www.goluckyvip.com/news/6075.html
Shopee纵向深度站外推广引爆秘诀:https://www.goluckyvip.com/news/6076.html
去日本入住酒店,东西随意用却有一个特殊“要:https://www.vstour.cn/a/411241.html
中国有哪些著名的酒店品牌。:https://www.vstour.cn/a/411242.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流