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