zoukankan      html  css  js  c++  java
  • 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 q
    inner join (
    select q.StartId,COUNT(1) as Total
    from q
    inner join dbo.userInfo a on a.OrgID=q.id
    group by q.StartId
    )m on q.id=m.StartId
    
  • 相关阅读:
    函数高阶(函数,改变函数this指向,高阶函数,闭包,递归)
    案例:新增数组方法
    案例:商品查询
    案例:forEach和some区别
    ES5新增方法(数组,字符串,对象)
    案例:借用父构造函数继承属性和方法
    构造函数 和 原型
    汽车小常识别让六大汽车驾驶软肋阻碍你
    Opencv 图像增强和亮度调整<6>
    C# StringBulider用法<1>
  • 原文地址:https://www.cnblogs.com/sword-successful/p/5062868.html
Copyright © 2011-2022 走看看