From 28c81c66bcd938dc4144b82e7ee2483ce25477ec Mon Sep 17 00:00:00 2001
From: Administrator <admin>
Date: Fri, 17 Sep 2021 22:14:52 +0800
Subject: [PATCH] 分局预警统计接口新增(统计各个辖区对应(表现差+审查异常+持证率低于50%公司个数+派遣率低于50%公司个数+社保缴纳率低于50%公司个数+考试通过率低于50%公司个数)预警总数)

---
 src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml |  203 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 203 insertions(+), 0 deletions(-)

diff --git a/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml b/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
index d3d5760..fa6b537 100644
--- a/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
+++ b/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
@@ -2050,6 +2050,7 @@
         ifnull(a.count,0) znum,
         ifnull(b.count,0) cnum,
         ifnull(FORMAT((b.count/c.count)*100,2),0) pnum
+        ifnull(c.count,0) knum,
         from sys_information si
         left join
         (
@@ -2127,6 +2128,7 @@
         d.jurisdiction = sj.id
         where 1=1
         and (d.stats = 2 or d.stats = 4)
+        and knum != 0
         and pnum &lt; #{information.proportion}
         <if test="information.jurisdiction!=null and information.jurisdiction!='' and information.jurisdiction!='1372091709474910209'">
             and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
@@ -2272,4 +2274,205 @@
             and b.departmentid = #{information.departmentid}
         </if>
     </select>
+
+
+    <!--统计表现差的信息-->
+    <select id="getSecurityPerformanceGroupCountList" resultType="org.springblade.modules.information.vo.ResponseVo">
+        select
+            a.id,a.dept_name name,ifnull(b.count,0) num
+        from
+            (select id,dept_name from sys_jurisdiction where parent_id = 1372091709474910209) a
+        left join
+        (
+            select
+                sj.id,sj.parent_id,count(*) count
+                from sys_performance sp
+                left join
+                blade_user bu
+                on
+                bu.id = sp.securityId
+                left join
+                sys_information si
+                on
+                bu.dept_id = si.departmentid
+                left join
+                sys_jurisdiction sj
+                on
+                sj.id = si.jurisdiction
+                where
+                1=1
+                and (si.stats = 2 or si.stats =4)
+                and bu.is_deleted = 0
+                and bu.`status` = 1
+                and sp.score = 3
+                group by si.jurisdiction
+         ) b
+              on
+        a.id = b.parent_id
+    </select>
+
+
+    <!--统计资格审查异常信息-->
+    <select id="getSecurityExaminationGroupCountList" resultType="org.springblade.modules.information.vo.ResponseVo">
+        select a.id,a.dept_name name,ifnull(b.count,0) num
+            from
+        (select id,dept_name from sys_jurisdiction where parent_id = 1372091709474910209) a
+            left join
+        (
+        select
+                sj.id,sj.parent_id,count(*) count
+                from
+                blade_user bu
+                left join
+                sys_information si
+                on
+                bu.dept_id = si.departmentid
+                left join
+                sys_jurisdiction sj
+                on
+                sj.id = si.jurisdiction
+                where
+                1=1
+                and (si.stats = 2 or si.stats =4)
+                and bu.is_deleted = 0
+                and bu.`status` = 1
+                and bu.examination_type = 1
+                group by si.jurisdiction
+         ) b
+            on
+        a.id = b.parent_id
+    </select>
+
+
+    <!--考试通过率低于50%-->
+    <select id="getSecurityExamPassingGroupCountList" resultType="org.springblade.modules.information.vo.ResponseVo">
+        select g.id,g.dept_name name,ifnull(f.count,0) num
+        from
+        (select id,dept_name from sys_jurisdiction where parent_id = 1372091709474910209) g
+        left join
+        (
+            select e.id,e.parent_id,count(*) count from (
+                select d.*,ifnull(FORMAT((num2/num1)*100,2),0) num3,sj.* from (
+                select a.dept_id,ifnull(b.count,0) num1,ifnull(c.count,0) num2 from
+                (
+                    select
+                    bu.dept_id,ifnull(count(*),0) count
+                    from blade_user bu
+                    left join blade_role br
+                    on bu.role_id = br.id
+                    where
+                    role_alias = "安保人员"
+                    and bu.is_deleted = 0
+                    and bu.`status` = 1
+                    group by dept_id
+                    ) a
+
+                    left join
+                    (
+                    select count(*) count,bu.dept_id from
+                    exam_score es
+                    left join
+                    blade_user bu
+                    on
+                    bu.id = es.user_id
+                    where 1=1 group by bu.dept_id
+                    ) b
+                    on
+                    a.dept_id = b.dept_id
+
+                    left join
+                    (
+                    select count(*) count,bu.dept_id from
+                    exam_score es
+                    left join
+                    blade_user bu
+                    on
+                    bu.id = es.user_id
+                    where qualified = 0 group by bu.dept_id
+                    ) c
+                    on a.dept_id = c.dept_id
+                )d
+                left join
+                sys_information si
+                on
+                si.departmentid = d.dept_id
+                left join
+                sys_jurisdiction sj
+                on
+                sj.id = si.jurisdiction
+                where d.num1!=0
+                and (stats = 2 or stats=4)
+            )e
+            where e.num3 &lt; 50
+            group by e.id
+        ) f
+        on
+        g.id = f.parent_id
+    </select>
+
+    <!--持证率低于50%,社保缴纳率低于50%,派遣率低于50%-->
+    <select id="getSecurityHoldAndSoidAndDispatchGroupCountList" resultType="org.springblade.modules.information.vo.ResponseVo">
+        select g.id,g.dept_name name,ifnull(f.count,0) num
+            from
+        (select id,dept_name from sys_jurisdiction where parent_id = 1372091709474910209) g
+            left join
+        (
+            select e.id,e.parent_id,count(*) count from (
+                select d.*,ifnull(FORMAT((num2/num1)*100,2),0) num3,sj.* from (
+                    select a.dept_id,ifnull(a.count,0) num1,ifnull(b.count,0) num2 from
+                    (
+                    select
+                    bu.dept_id,ifnull(count(*),0) count
+                    from blade_user bu
+                    left join blade_role br
+                    on bu.role_id = br.id
+                    where
+                    role_alias = "安保人员"
+                    and bu.is_deleted = 0
+                    and bu.`status` = 1
+                    group by dept_id
+                    ) a
+
+                    left join
+                    (
+                    select
+                    bu.dept_id,ifnull(count(*),0) count
+                    from blade_user bu
+                    left join blade_role br
+                    on bu.role_id = br.id
+                    where
+                    role_alias = "安保人员"
+                    and bu.is_deleted = 0
+                    and bu.`status` = 1
+                    <if test="type==1">
+                        and bu.hold = 1
+                    </if>
+                    <if test="type==2">
+                        and bu.dispatch = 0
+                    </if>
+                    <if test="type==3">
+                        and bu.soil = 0
+                    </if>
+                    group by dept_id
+                    ) b
+                    on
+                    a.dept_id = b.dept_id
+                )d
+                left join
+                sys_information si
+                on
+                si.departmentid = d.dept_id
+                left join
+                sys_jurisdiction sj
+                on
+                sj.id = si.jurisdiction
+                and (stats = 2 or stats=4)
+            )e
+            where e.num3 &lt; 50
+            group by e.id
+        ) f
+            on
+        g.id = f.parent_id
+    </select>
+
 </mapper>

--
Gitblit v1.9.3