SQL Server利用递归把所有【子部门员工】汇总到【一级根节点部门】
2015-12-21 11:23
836 查看
前言
说起这个需求,有点反常规,左边是组织机构树,右边是组织机构对应的员工列表。点击左侧组织机构时传一个组织机构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
相关文章推荐
- Mysql多实例
- Oracle常用命令记录
- shp文件坐标系转换-PostGIS
- MYSQL主从同步
- 阿里巴巴开源项目: canal 基于mysql数据库binlog的增量订阅&消费
- 数据库的一些基本概念
- 在执行Ado.net SqlDataAdapter 查询超时设置
- ORA-16957: SQL Analyze time limit interrupt
- mysql 连接语句
- mysql 查询
- SQL Server 错误日志收缩(ERRORLOG)
- SQL Server 重置Identity标识列的值(INT爆了)
- mysql 表日常变化前几
- Mysql5.5安装
- Oracle dblink详解
- 2008 MSSQL的一个镜像安装步骤
- 25. oracle密码过期解决
- 用sqlyog打开.sql文件
- SQL优化--Exists和in的效率哪个高
- 采用Atlas+Keepalived实现MySQL读写分离、读负载均衡