首页 技术 正文
技术 2022年11月20日
0 收藏 562 点赞 4,027 浏览 896 个字

前言

说起这个需求,有点反常规,左边是组织机构树,右边是组织机构对应的员工列表。点击左侧组织机构时传一个组织机构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
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,906
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,430
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,247
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,058
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,690
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,727