智慧保安后台管理项目备份
Administrator
2021-09-18 3b1e22dc8460daafc2ecbae478ddcbe5ea21b944
src/main/java/org/springblade/modules/information/mapper/InformationMapper.xml
@@ -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,
        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
        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
        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,
        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
        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 (
        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
        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>-->
    <!--查询本年所有月份的总人数-->
@@ -1018,6 +1077,35 @@
        </if>
        GROUP BY d.dept_name,
        j.dept_name
    </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;-->
@@ -1842,10 +1930,9 @@
    <!--获取保安公司信息(本市保安公司,分公司)包含经纬度-->
    <select id="getSecurityUnitPositionInfo" resultType="org.springblade.modules.information.vo.InformationVO">
        select
        si.*,sj.dept_name jurisdictionName
        from
        sys_information si
        select si.*,
               sj.dept_name jurisdictionName
        from sys_information si
        left join
        sys_jurisdiction sj
        on
@@ -1872,8 +1959,8 @@
    </select>
    <sql id="getSecurity">
        select
            dept_id,ifnull(count(*),0) count
        select dept_id,
               ifnull(count(*), 0) count
            from blade_user bu
            left join blade_role br
            on bu.role_id = br.id
@@ -2755,5 +2842,35 @@
    </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>