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