From f6abb1756eb209c072285b113ba1b79068a85fe2 Mon Sep 17 00:00:00 2001
From: tangzy <tangzy123456>
Date: Sat, 28 Aug 2021 15:58:44 +0800
Subject: [PATCH] 1.统计

---
 src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml |   95 ++++++++++++++++++++++++++++-------------------
 1 files changed, 57 insertions(+), 38 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 a07d0bd..15edf68 100644
--- a/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
+++ b/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
@@ -142,49 +142,68 @@
 
     <!--资格审查异常数量-->
     <select id="selectExtype" resultType="java.util.HashMap">
-        SELECT IFNULL(A.num,0) AS zc,IFNULL(B.num ,0) AS bzc
-        FROM (
-        SELECT COUNT(*) AS num,
-        u.dept_id,u.jurisdiction
-        FROM blade_user u
-        WHERE u.examination_type = 0
-        GROUP BY u.dept_id,u.jurisdiction
-        ) A
-        LEFT JOIN (
-        SELECT COUNT(*) AS num,
-        u.dept_id,u.jurisdiction
-        FROM blade_user u
-        WHERE u.examination_type = 1
-        GROUP BY u.dept_id,u.jurisdiction
-        ) B ON A.dept_id = B.dept_id
-        <if test="jurisdiction!=null and jurisdiction=='' and jurisdiction!='1123598813738675201'">
-            WHERE A.jurisdiction = #{jurisdiction}
+        SELECT
+        IFNULL( A.num, 0 ) AS zc,
+        IFNULL( B.num, 0 ) AS bzc
+        FROM
+        (
+        SELECT departmentid, jurisdiction FROM sys_information GROUP BY departmentid, jurisdiction ) H
+        LEFT JOIN ( SELECT COUNT(*) AS num, u.dept_id FROM blade_user u WHERE u.examination_type = 0 GROUP BY u.dept_id
+        ) A ON H.departmentid = A.dept_id
+        LEFT JOIN ( SELECT COUNT(*) AS num, u.dept_id FROM blade_user u WHERE u.examination_type = 1 GROUP BY u.dept_id
+        ) B ON H.departmentid = B.dept_id where 1=1
+        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1123598813738675201'">
+            and H.jurisdiction = #{jurisdiction}
         </if>
         <if test="deptid!=null and deptid!=''">
-            WHERE A.dept_id = #{deptid}
+            and H.departmentid = #{deptid}
         </if>
     </select>
 
 
     <!--保安员持证和未持证数量-->
     <select id="selectHold" resultType="java.util.HashMap">
-        SELECT IFNULL(A.thisnum, 0) AS cz,
-        IFNULL(B.lastnum, 0) AS wcz
-        FROM (SELECT COUNT(*) AS thisnum, dept_id,jurisdiction
-        FROM blade_user
-        WHERE role_id = '1412226235153731586' AND `status`=1 AND is_deleted=0
+        SELECT
+        IFNULL( A.thisnum, 0 ) AS cz,
+        IFNULL( B.lastnum, 0 ) AS wcz
+        FROM
+        (
+        SELECT departmentid,jurisdiction FROM sys_information GROUP BY departmentid,jurisdiction
+        ) H
+        LEFT JOIN(
+        SELECT
+        COUNT( * ) AS thisnum,
+        dept_id
+        FROM
+        blade_user
+        WHERE
+        ( role_id = '1412226235153731586' OR role_id = '1416733602219110402' )
+        AND `status` = 1
+        AND is_deleted = 0
         AND hold = 1
-        GROUP BY dept_id,jurisdiction) A
-        LEFT JOIN (SELECT COUNT(*) AS lastnum, dept_id,jurisdiction
-        FROM blade_user
-        WHERE role_id = '1412226235153731586' AND `status`=1 AND is_deleted=0
+        GROUP BY
+        dept_id
+        ) A ON A.dept_id=H.departmentid
+        LEFT JOIN (
+        SELECT
+        COUNT(*) AS lastnum,
+        dept_id
+        FROM
+        blade_user
+        WHERE
+        ( role_id = '1412226235153731586' OR role_id = '1416733602219110402' )
+        AND `status` = 1
+        AND is_deleted = 0
         AND hold = 2
-        GROUP BY dept_id,jurisdiction) B ON A.dept_id = B.dept_id
-        <if test="jurisdiction!=null and jurisdiction=='' and jurisdiction!='1123598813738675201'">
-            WHERE A.jurisdiction = #{jurisdiction}
-        </if>
+        GROUP BY
+        dept_id
+        ) B ON B.dept_id=H.departmentid
+        where 1=1
         <if test="deptid!=null and deptid!=''">
-            WHERE A.dept_id = #{deptid}
+            and H.departmentid = #{deptid}
+        </if>
+        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1123598813738675201'">
+            and H.jurisdiction = #{jurisdiction}
         </if>
     </select>
     <!--派遣服务单位统计-->
@@ -209,12 +228,12 @@
         FROM blade_user
         WHERE role_id = '1412226235153731586' AND `status`=1 AND is_deleted=0
         AND dispatch = 0
-        GROUP BY dept_id,jurisdiction) B ON A.dept_id = B.dept_id
+        GROUP BY dept_id,jurisdiction) B ON A.dept_id = B.dept_id where 1=1
         <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1123598813738675201'">
-            WHERE A.jurisdiction = #{jurisdiction}
+            and A.jurisdiction = #{jurisdiction}
         </if>
         <if test="deptid!=null and deptid!=''">
-            WHERE A.dept_id = #{deptid}
+            and A.dept_id = #{deptid}
         </if>
     </select>
 
@@ -228,12 +247,12 @@
         GROUP BY dept_id) A ON A.dept_id = H.departmentid
         LEFT JOIN (SELECT COUNT(*) AS numz, dept_id FROM blade_user WHERE `status` = 1 AND is_deleted = 0 GROUP BY
         dept_id) B
-        ON H.departmentid = B.dept_id
+        ON H.departmentid = B.dept_id where 1=1
         <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1123598813738675201'">
-            WHERE H.jurisdiction = #{jurisdiction}
+            and H.jurisdiction = #{jurisdiction}
         </if>
         <if test="deptid!=null and deptid!=''">
-            WHERE H.departmentid = #{deptid}
+            and H.departmentid = #{deptid}
         </if>
     </select>
 

--
Gitblit v1.9.3