From 03f42f3e256dbc2e0c4e9b7ce3cb6a85df7cf130 Mon Sep 17 00:00:00 2001
From: tangzy <tangzy123456>
Date: Fri, 27 Aug 2021 20:40:40 +0800
Subject: [PATCH] 1.统计

---
 src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml |  118 +++++++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 83 insertions(+), 35 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 39c3a81..c5d8228 100644
--- a/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
+++ b/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
@@ -38,7 +38,9 @@
 
 
     <insert id="insertIn" useGeneratedKeys="true" keyProperty="id">
-        insert into sys_information(creditcode, enterprisename,representative, establishtime, registeredcapital,organizationcode, registrationnumber, identificationnumber, enterprises, address,business, region, registration, industry, departmentid, stats, jurisdiction,
+        insert into sys_information(creditcode, enterprisename, representative, establishtime, registeredcapital,
+                                    organizationcode, registrationnumber, identificationnumber, enterprises, address,
+                                    business, region, registration, industry, departmentid, stats, jurisdiction,
                                     representativecell, contacts, contactscell)
         values (#{information.creditcode}, #{information.enterprisename}, #{information.representative},
                 #{information.establishtime}, #{information.registeredcapital},
@@ -59,10 +61,13 @@
         IFNULL(C.pnum ,0) as pnum
         FROM
         sys_information i
-        LEFT JOIN ( SELECT COUNT( * ) AS znum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' 	AND status=1  GROUP BY dept_id ) A ON A.dept_id = i.departmentid
-        LEFT JOIN ( SELECT COUNT( * ) AS cnum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' 	AND status=1  AND hold=1 GROUP BY dept_id ) B ON B.dept_id = i.departmentid
-        LEFT JOIN ( SELECT COUNT( * ) AS pnum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' 	AND status=1  AND dispatch=0 GROUP BY dept_id ) C ON C.dept_id = i.departmentid
-        where  1=1
+        LEFT JOIN ( SELECT COUNT( * ) AS znum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' AND
+        status=1 GROUP BY dept_id ) A ON A.dept_id = i.departmentid
+        LEFT JOIN ( SELECT COUNT( * ) AS cnum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' AND
+        status=1 AND hold=1 GROUP BY dept_id ) B ON B.dept_id = i.departmentid
+        LEFT JOIN ( SELECT COUNT( * ) AS pnum, dept_id FROM blade_user WHERE role_id = '1412226235153731586' AND
+        status=1 AND dispatch=0 GROUP BY dept_id ) C ON C.dept_id = i.departmentid
+        where 1=1
         <if test="information.enterprisename!=null and information.enterprisename!=''">
             and i.enterpriseName like concat(concat('%', #{information.enterprisename}),'%')
         </if>
@@ -137,39 +142,50 @@
 
     <!--资格审查异常数量-->
     <select id="selectExtype" resultType="java.util.HashMap">
-        SELECT A.num as zc,
-               B.num as bzc
+        SELECT IFNULL(A.num,0) AS zc,IFNULL(B.num ,0) AS bzc
         FROM (
-                 SELECT COUNT(*) AS num,
-                        u.dept_id
-                 FROM blade_user u
-                 WHERE u.examination_type = 0
-                 GROUP BY u.dept_id
-             ) A
-                 LEFT JOIN (
-            SELECT COUNT(*) AS num,
-                   u.dept_id
-            FROM blade_user u
-            WHERE u.examination_type = 1
-            GROUP BY u.dept_id
+        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
-        WHERE A.dept_id = #{deptid}
+        <if test="jurisdiction!=null and jurisdiction==''">
+            WHERE A.jurisdiction = #{jurisdiction}
+        </if>
+        <if test="deptid!=null and deptid==''">
+            WHERE A.dept_id = #{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
-              FROM blade_user
-              WHERE role_id = '1412226235153731586' AND hold = 1
-              GROUP BY dept_id) A
-                 LEFT JOIN (SELECT COUNT(*) AS lastnum, dept_id
-                            FROM blade_user
-                            WHERE role_id = '1412226235153731586' AND hold = 2
-                            GROUP BY dept_id) B ON A.dept_id = B.dept_id
-        WHERE A.dept_id =#{deptid}
+        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
+        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
+        AND hold = 2
+        GROUP BY dept_id,jurisdiction) B ON A.dept_id = B.dept_id
+        <if test="jurisdiction!=null and jurisdiction==''">
+            WHERE A.jurisdiction = #{jurisdiction}
+        </if>
+        <if test="deptid!=null and deptid==''">
+            WHERE A.dept_id = #{deptid}
+        </if>
     </select>
     <!--派遣服务单位统计-->
     <select id="selectDis" resultType="java.util.HashMap">
@@ -201,13 +217,13 @@
     <!--查询培训单位信息(可以报名)-->
     <select id="securityPage" resultType="org.springblade.modules.information.vo.InformationVO">
         select
-            si.*,bd.dept_name deptName
+        si.*,bd.dept_name deptName
         from
-           sys_information si
+        sys_information si
         left join
-            blade_dept bd
+        blade_dept bd
         on
-            si.departmentid = bd.id
+        si.departmentid = bd.id
         where 1=1
         and bd.dept_category = 3
         <if test="information.deptName!=null and information.deptName!=''">
@@ -224,5 +240,37 @@
         </if>
     </select>
 
-
+    <!--查询本年所有月份的客户数量-->
+    <select id="queryYearKh" resultType="java.util.HashMap">
+        SELECT COUNT
+        (CASE WHEN MONTH (
+        s.start_time ) = 1 THEN s.id END ) AS '1', COUNT(CASE WHEN MONTH ( s.start_time ) = 2
+        THEN s.id END ) AS '2', COUNT(CASE WHEN MONTH ( s.start_time ) = 3 THEN s.id
+        END ) AS '3', COUNT(CASE WHEN MONTH ( s.start_time ) = 4 THEN s.id END ) AS '4', COUNT(CASE
+        WHEN MONTH ( s.start_time ) = 5 THEN s.id END ) AS '5', COUNT(CASE WHEN MONTH (
+        s.start_time ) = 6 THEN s.id END ) AS '6', COUNT(CASE WHEN MONTH ( s.start_time ) = 7
+        THEN s.id END ) AS '7', COUNT(CASE WHEN MONTH ( s.start_time ) = 8 THEN s.id
+        END ) AS '8', COUNT(CASE WHEN MONTH ( s.start_time ) = 9 THEN s.id END ) AS '9', COUNT(CASE
+        WHEN MONTH ( s.start_time ) = 10 THEN s.id END ) AS '10', COUNT(CASE WHEN MONTH (
+        s.start_time ) = 11 THEN s.id END ) AS '11', COUNT(CASE WHEN MONTH ( s.start_time ) = 12
+        THEN s.id END ) AS '12'
+        FROM sys_dispatcher_unit AS s
+        WHERE
+        YEAR ( s.start_time ) =#{year}
+        AND dept_id IN (
+        SELECT
+        i.departmentid
+        FROM
+        sys_information i
+        LEFT JOIN sys_jurisdiction j ON j.id= i.jurisdiction where 1=1
+        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1123598813738675201'">
+            and i.jurisdiction =#{jurisdiction}
+        </if>
+        GROUP BY
+        i.departmentid
+        )
+        <if test="deptid!=null and deptid!=''">
+            and dept_id =#{deptid}
+        </if>
+    </select>
 </mapper>

--
Gitblit v1.9.3