From e0f70be7e7a2ad0fe3a71956caf2327093fbbe03 Mon Sep 17 00:00:00 2001
From: tangzy <tangzy123456>
Date: Sat, 18 Sep 2021 08:55:59 +0800
Subject: [PATCH] 1.统计接口

---
 src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml |  393 ++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 254 insertions(+), 139 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 6333a91..da56837 100644
--- a/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
+++ b/src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
@@ -137,43 +137,43 @@
     </select>
 
     <!--通过辖区查询机构id,然后通过机构id查询当前机构交社保的人数(numj单位已交社保数量;numz单位人员总数)-->
-<!--    <select id="selectCs" resultType="java.util.HashMap">-->
-<!--        SELECT A.numj,-->
-<!--        B.numz,-->
-<!--        d.dept_name as deptname-->
-<!--        FROM (-->
-<!--        SELECT COUNT-->
-<!--        (*) AS numj,-->
-<!--        deptid-->
-<!--        FROM sys_socil-->
-<!--        WHERE deptid 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!='1372091709474910209'">-->
-<!--            and i.jurisdiction in(${jurisdiction})-->
-<!--        </if>-->
-<!--        GROUP BY i.departmentid)-->
-<!--        GROUP BY deptid-->
-<!--        ) A-->
-<!--        left JOIN (-->
-<!--        SELECT COUNT-->
-<!--        (*) AS numz,-->
-<!--        dept_id-->
-<!--        FROM blade_user-->
-<!--        WHERE 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!='1372091709474910209'">-->
-<!--            and i.jurisdiction in(${jurisdiction})-->
-<!--        </if>-->
-<!--        GROUP BY i.departmentid)-->
-<!--        GROUP BY dept_id-->
-<!--        ) B ON A.deptid = B.dept_id-->
-<!--        LEFT JOIN (SELECT id, dept_name FROM blade_dept) d ON d.id = A.deptid where 1=1-->
-<!--        <if test="deptid!=null and deptid!=''">-->
-<!--            and A.deptid =#{deptid}-->
-<!--        </if>-->
-<!--    </select>-->
+    <!--    <select id="selectCs" resultType="java.util.HashMap">-->
+    <!--        SELECT A.numj,-->
+    <!--        B.numz,-->
+    <!--        d.dept_name as deptname-->
+    <!--        FROM (-->
+    <!--        SELECT COUNT-->
+    <!--        (*) AS numj,-->
+    <!--        deptid-->
+    <!--        FROM sys_socil-->
+    <!--        WHERE deptid 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!='1372091709474910209'">-->
+    <!--            and i.jurisdiction in(${jurisdiction})-->
+    <!--        </if>-->
+    <!--        GROUP BY i.departmentid)-->
+    <!--        GROUP BY deptid-->
+    <!--        ) A-->
+    <!--        left JOIN (-->
+    <!--        SELECT COUNT-->
+    <!--        (*) AS numz,-->
+    <!--        dept_id-->
+    <!--        FROM blade_user-->
+    <!--        WHERE 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!='1372091709474910209'">-->
+    <!--            and i.jurisdiction in(${jurisdiction})-->
+    <!--        </if>-->
+    <!--        GROUP BY i.departmentid)-->
+    <!--        GROUP BY dept_id-->
+    <!--        ) B ON A.deptid = B.dept_id-->
+    <!--        LEFT JOIN (SELECT id, dept_name FROM blade_dept) d ON d.id = A.deptid where 1=1-->
+    <!--        <if test="deptid!=null and deptid!=''">-->
+    <!--            and A.deptid =#{deptid}-->
+    <!--        </if>-->
+    <!--    </select>-->
     <select id="selectCs" resultType="java.util.HashMap">
         SELECT COUNT(*) as numj,jurisdiction
         FROM blade_user
@@ -540,57 +540,90 @@
 
 
     <!--总保安数量-->
+<!--    <select id="queryCountB" resultType="java.util.HashMap">-->
+<!--        SELECT-->
+<!--        C.thisnum,-->
+<!--        C.lastnum,-->
+<!--        d.dept_name AS deptname,-->
+<!--        j.dept_name AS jurname-->
+<!--        FROM-->
+<!--        (-->
+<!--        SELECT-->
+<!--        IFNULL( A.thisnum, 0 ) AS thisnum,-->
+<!--        IFNULL( B.lastnum, 0 ) AS lastnum,-->
+<!--        A.dept_id,-->
+<!--        A.jurisdiction-->
+<!--        FROM-->
+<!--        (-->
+<!--        SELECT-->
+<!--        COUNT( * ) AS thisnum,-->
+<!--        dept_id,-->
+<!--        jurisdiction-->
+<!--        FROM-->
+<!--        blade_user-->
+<!--        WHERE-->
+<!--        role_id = '1412226235153731586' and status=1 and is_deleted=0-->
+<!--        AND DATE_FORMAT( create_time, '%Y%m' ) = DATE_FORMAT( CURDATE( ), '%Y%m' )-->
+<!--        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 PERIOD_DIFF( date_format( now( ), '%Y%m' ), date_format( create_time, '%Y%m' ) ) = 1-->
+<!--        GROUP BY-->
+<!--        dept_id,-->
+<!--        jurisdiction-->
+<!--        ) B ON A.dept_id = B.dept_id-->
+<!--        ) C-->
+<!--        LEFT JOIN blade_dept d ON C.dept_id = d.id-->
+<!--        LEFT JOIN sys_jurisdiction j ON j.id = C.jurisdiction-->
+<!--        WHERE 1 =1-->
+<!--        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1372091709474910209'">-->
+<!--            and C.jurisdiction =#{jurisdiction}-->
+<!--        </if>-->
+<!--        <if test="deptid!=null and deptid!=''">-->
+<!--            and C.dept_id =#{deptid}-->
+<!--        </if>-->
+<!--    </select>-->
     <select id="queryCountB" resultType="java.util.HashMap">
-        SELECT
-        C.thisnum,
-        C.lastnum,
-        d.dept_name AS deptname,
-        j.dept_name AS jurname
-        FROM
-        (
-        SELECT
-        IFNULL( A.thisnum, 0 ) AS thisnum,
-        IFNULL( B.lastnum, 0 ) AS lastnum,
-        A.dept_id,
-        A.jurisdiction
-        FROM
-        (
-        SELECT
-        COUNT( * ) AS thisnum,
-        dept_id,
-        jurisdiction
-        FROM
-        blade_user
-        WHERE
-        role_id = '1412226235153731586' and status=1 and is_deleted=0
-        AND DATE_FORMAT( create_time, '%Y%m' ) = DATE_FORMAT( CURDATE( ), '%Y%m' )
-        GROUP BY
-        dept_id,
-        jurisdiction
-        ) A
+        SELECT IFNULL(A.thisnum, 0) AS thisnum,
+        IFNULL(B.lastnum, 0) AS lastnum,
+        H.departmentid,
+        H.jurisdiction
+        FROM (SELECT departmentid, jurisdiction FROM sys_information GROUP BY departmentid, jurisdiction) H
         LEFT JOIN (
-        SELECT
-        COUNT( * ) AS lastnum,
-        dept_id,
-        jurisdiction
-        FROM
-        blade_user
-        WHERE
-        role_id = '1412226235153731586' and status=1 and is_deleted=0
-        AND PERIOD_DIFF( date_format( now( ), '%Y%m' ), date_format( create_time, '%Y%m' ) ) = 1
-        GROUP BY
-        dept_id,
-        jurisdiction
-        ) B ON A.dept_id = B.dept_id
-        ) C
-        LEFT JOIN blade_dept d ON C.dept_id = d.id
-        LEFT JOIN sys_jurisdiction j ON j.id = C.jurisdiction
-        WHERE 1 =1
+        SELECT COUNT(*) AS thisnum,
+        dept_id
+        FROM blade_user
+        WHERE role_id = '1412226235153731586'
+        AND STATUS = 1
+        AND is_deleted = 0
+        AND DATE_FORMAT(create_time, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m')
+        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'
+        AND STATUS = 1
+        AND is_deleted = 0
+        AND PERIOD_DIFF(date_format(now(), '%Y%m'), date_format(create_time, '%Y%m')) = 1
+        GROUP BY dept_id
+        ) B ON B.dept_id = H.departmentid where 1=1
         <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1372091709474910209'">
-            and C.jurisdiction =#{jurisdiction}
+            and H.jurisdiction =#{jurisdiction}
         </if>
         <if test="deptid!=null and deptid!=''">
-            and C.dept_id =#{deptid}
+            and H.departmentid =#{deptid}
         </if>
     </select>
 
@@ -771,40 +804,66 @@
 
     <!--保安派遣数量-->
     <select id="queryCountPq" resultType="java.util.HashMap">
-        SELECT C.thisnum,
-        C.lastnum,
-        d.dept_name as deptname,
-        j.dept_name as jurname
-        FROM (
-        SELECT IFNULL(A.thisnum, 0) AS thisnum,
-        IFNULL(B.lastnum, 0) AS lastnum,
-        A.dept_id,
-        A.jurisdiction
-        FROM (
+        SELECT IFNULL(G.thisnum, 0) AS thisnum,
+        IFNULL(J.lastnum, 0) AS lastnum
+        FROM (SELECT departmentid, jurisdiction FROM sys_information GROUP BY departmentid, jurisdiction) H
+        LEFT JOIN (
         SELECT SUM(num) AS thisnum,
-        dept_id,
-        jurisdiction
+        dept_id
         FROM sys_dispatcher
-        WHERE DATE_FORMAT( dispatcherTime, '%Y%m' ) = DATE_FORMAT( CURDATE( ), '%Y%m' )
-        GROUP BY dept_id, jurisdiction
-        ) A
-        left JOIN (
+        WHERE DATE_FORMAT(dispatcherTime, '%Y%m') = DATE_FORMAT(CURDATE(), '%Y%m')
+        GROUP BY dept_id
+        ) G ON G.dept_id = H.departmentid
+        LEFT JOIN (
         SELECT SUM(num) AS lastnum,
-        dept_id,
-        jurisdiction
+        dept_id
         FROM sys_dispatcher
-        WHERE PERIOD_DIFF( date_format( now( ), '%Y%m' ), date_format( dispatcherTime, '%Y%m' ) ) = 1
-        GROUP BY dept_id, jurisdiction
-        ) B ON A.dept_id = B.dept_id) C
-        LEFT JOIN blade_dept d ON C.dept_id = d.id
-        LEFT JOIN sys_jurisdiction j ON j.id = C.jurisdiction where 1=1
+        WHERE PERIOD_DIFF(date_format(now(), '%Y%m'), date_format(dispatcherTime, '%Y%m')) = 1
+        GROUP BY dept_id
+        ) J ON J.dept_id = H.departmentid
+        WHERE 1 = 1
         <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1372091709474910209'">
-            and C.jurisdiction =#{jurisdiction}
+            and H.jurisdiction =#{jurisdiction}
         </if>
         <if test="deptid!=null and deptid!=''">
-            and C.dept_id =#{deptid}
+            and H.departmentid =#{deptid}
         </if>
     </select>
+<!--    <select id="queryCountPq" resultType="java.util.HashMap">-->
+<!--        SELECT C.thisnum,-->
+<!--        C.lastnum,-->
+<!--        d.dept_name as deptname,-->
+<!--        j.dept_name as jurname-->
+<!--        FROM (-->
+<!--        SELECT IFNULL(A.thisnum, 0) AS thisnum,-->
+<!--        IFNULL(B.lastnum, 0) AS lastnum,-->
+<!--        A.dept_id,-->
+<!--        A.jurisdiction-->
+<!--        FROM (-->
+<!--        SELECT SUM(num) AS thisnum,-->
+<!--        dept_id,-->
+<!--        jurisdiction-->
+<!--        FROM sys_dispatcher-->
+<!--        WHERE DATE_FORMAT( dispatcherTime, '%Y%m' ) = DATE_FORMAT( CURDATE( ), '%Y%m' )-->
+<!--        GROUP BY dept_id, jurisdiction-->
+<!--        ) A-->
+<!--        left JOIN (-->
+<!--        SELECT SUM(num) AS lastnum,-->
+<!--        dept_id,-->
+<!--        jurisdiction-->
+<!--        FROM sys_dispatcher-->
+<!--        WHERE PERIOD_DIFF( date_format( now( ), '%Y%m' ), date_format( dispatcherTime, '%Y%m' ) ) = 1-->
+<!--        GROUP BY dept_id, jurisdiction-->
+<!--        ) B ON A.dept_id = B.dept_id) C-->
+<!--        LEFT JOIN blade_dept d ON C.dept_id = d.id-->
+<!--        LEFT JOIN sys_jurisdiction j ON j.id = C.jurisdiction where 1=1-->
+<!--        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1372091709474910209'">-->
+<!--            and C.jurisdiction =#{jurisdiction}-->
+<!--        </if>-->
+<!--        <if test="deptid!=null and deptid!=''">-->
+<!--            and C.dept_id =#{deptid}-->
+<!--        </if>-->
+<!--    </select>-->
 
 
     <!--查询本年所有月份的总人数-->
@@ -1020,12 +1079,41 @@
         j.dept_name
     </select>
 
-<!--    &lt;!&ndash;查询出所有辖区信息&ndash;&gt;-->
-<!--    <select id="selectJur" resultType="java.util.HashMap">-->
-<!--        SELECT id, dept_name-->
-<!--        FROM sys_jurisdiction-->
-<!--        WHERE id!=1372091709474910209-->
-<!--    </select> -->
+
+    <select id="selectBxs" resultType="java.util.HashMap">
+        select
+            si.jurisdiction id,
+            sj.parent_id,
+            sj.dept_name jurisdictionName,
+            si.enterprisename,
+            "表现差" detail
+        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
+    </select>
+
+    <!--    &lt;!&ndash;查询出所有辖区信息&ndash;&gt;-->
+    <!--    <select id="selectJur" resultType="java.util.HashMap">-->
+    <!--        SELECT id, dept_name-->
+    <!--        FROM sys_jurisdiction-->
+    <!--        WHERE id!=1372091709474910209-->
+    <!--    </select> -->
 
     <select id="selectExtypeUser" resultType="java.lang.Integer">
         SELECT COUNT(CASE WHEN (examination_mx IS NOT NULL OR examination_mx != "") THEN 1 END) AS sum
@@ -1842,16 +1930,15 @@
 
     <!--获取保安公司信息(本市保安公司,分公司)包含经纬度-->
     <select id="getSecurityUnitPositionInfo" resultType="org.springblade.modules.information.vo.InformationVO">
-        select
-        si.*,sj.dept_name jurisdictionName
-        from
-        sys_information si
-        left join
-        sys_jurisdiction sj
-        on
-        si.jurisdiction = sj.id
-        where 1=1
-        and (stats = 2 or stats = 4)
+        select si.*,
+               sj.dept_name jurisdictionName
+        from sys_information si
+                 left join
+             sys_jurisdiction sj
+             on
+                 si.jurisdiction = sj.id
+        where 1 = 1
+          and (stats = 2 or stats = 4)
     </select>
 
     <!--根据辖区查询保安公司分页信息(本市保安公司,分公司)-->
@@ -1867,20 +1954,20 @@
         where 1=1
         and (stats = 0 or stats = 1 or stats = 2 or stats = 4)
         <if test="information.jurisdiction!=null and information.jurisdiction!=''">
-            and (sj.id = #{information.jurisdiction} or sj.parent_id =  #{information.jurisdiction})
+            and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
         </if>
     </select>
 
     <sql id="getSecurity">
-        select
-            dept_id,ifnull(count(*),0) count
-            from blade_user bu
+        select dept_id,
+               ifnull(count(*), 0) count
+        from blade_user bu
             left join blade_role br
-            on bu.role_id = br.id
-            where
+        on bu.role_id = br.id
+        where
             role_alias = "安保人员"
-            and bu.is_deleted = 0
-            and bu.`status` = 1
+          and bu.is_deleted = 0
+          and bu.`status` = 1
     </sql>
 
     <!--根据辖区查询统计保安公司持证情况分页信息(本市保安公司,分公司)-->
@@ -1921,7 +2008,7 @@
         where 1=1
         and (si.stats = 2 or si.stats = 4)
         <if test="information.jurisdiction!=null and information.jurisdiction!=''">
-            and (sj.id = #{information.jurisdiction} or sj.parent_id =  #{information.jurisdiction})
+            and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
         </if>
     </select>
 
@@ -1969,7 +2056,7 @@
         and (c.stats = 2 or c.stats = 4)
         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})
+            and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
         </if>
         <if test="information.departmentid!=null and information.departmentid!=''">
             and c.departmentid = #{information.departmentid}
@@ -2064,7 +2151,7 @@
         and (d.stats = 2 or d.stats = 4)
         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})
+            and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
         </if>
     </select>
 
@@ -2189,7 +2276,7 @@
         sj.id = si.jurisdiction
         left join
         (
-        select  ifnull(count(*),0) count,dept_id from sys_dispatcher_unit
+        select ifnull(count(*),0) count,dept_id from sys_dispatcher_unit
         where 1=1
         and start_time &lt;= now()
         and end_time &gt; now()
@@ -2199,7 +2286,7 @@
         a.dept_id = si.departmentid
         where 1=1
         <if test="information.jurisdiction!=null and information.jurisdiction!='' and information.jurisdiction!='1372091709474910209'">
-            and (sj.id = #{information.jurisdiction} or sj.parent_id =  #{information.jurisdiction})
+            and (sj.id = #{information.jurisdiction} or sj.parent_id = #{information.jurisdiction})
         </if>
         ) b
         where b.znum &lt; 2
@@ -2207,7 +2294,35 @@
             and b.departmentid = #{information.departmentid}
         </if>
     </select>
-
-
+    <select id="seleP" resultType="java.util.HashMap">
+        SELECT
+        IFNULL(G.pnum, 0) AS pnum,
+        IFNULL(J.wpnum, 0) AS wpnum
+        FROM (SELECT departmentid, jurisdiction FROM sys_information GROUP BY departmentid, jurisdiction) H
+        LEFT JOIN (
+        SELECT COUNT(*) AS pnum,
+        dept_id
+        FROM blade_user
+        WHERE dispatch = 0
+        AND STATUS = 1
+        AND is_deleted = 0
+        GROUP BY dept_id
+        ) G ON G.dept_id = H.departmentid
+        LEFT JOIN (
+        SELECT COUNT(*) AS wpnum,
+        dept_id
+        FROM blade_user
+        WHERE dispatch = 1
+        AND STATUS = 1
+        AND is_deleted = 0
+        GROUP BY dept_id
+        ) J ON J.dept_id = H.departmentid where 1=1
+        <if test="jurisdiction!=null and jurisdiction!='' and jurisdiction!='1372091709474910209'">
+            and H.jurisdiction =#{jurisdiction}
+        </if>
+        <if test="deptid!=null and deptid!=''">
+            and H.departmentid =#{deptid}
+        </if>
+    </select>
 
 </mapper>

--
Gitblit v1.9.3