From e79d8c8f9679839bf983341fe2cf3212e1bb3001 Mon Sep 17 00:00:00 2001
From: wangwh <2397901735@qq.com>
Date: Mon, 28 Oct 2024 14:44:33 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/gzdyh_test' into gzdyh_test

---
 dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml |  149 +++++++++++++++++++++++++++++++++++++------------
 1 files changed, 111 insertions(+), 38 deletions(-)

diff --git a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml
index ea18c9a..2cd8bc4 100644
--- a/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml
+++ b/dyh-service/dyh-mediate/src/main/java/cn/huge/module/cases/dao/mapper/xml/CaseInfoMapper.xml
@@ -299,7 +299,7 @@
     <sql id="where-part-all">
         <if test="terms != null">
             <where>
-                and delete_status = 0
+                and a.delete_status = 0
                 <if test="terms.ids != null and terms.ids.size > 0">
                     and a.id in
                     <foreach collection="terms.ids" item="id" index="index" open="(" separator="," close=")">
@@ -323,6 +323,15 @@
                 </if>
                 <if test="terms.caseType != null and terms.caseType !=''">
                     and a.case_type = #{terms.caseType}
+                </if>
+                <if test="terms.caseTypeFirst != null and terms.caseTypeFirst !=''">
+                    and a.case_type_first = #{terms.caseTypeFirst}
+                </if>
+                <if test="terms.caseTypeFirstList != null and terms.caseTypeFirstList.size > 0">
+                    and a.case_type_first in
+                    <foreach collection="terms.caseTypeFirstList" item="caseTypeFirst" index="index" open="(" separator="," close=")">
+                        #{caseTypeFirst}
+                    </foreach>
                 </if>
                 <if test="terms.caseTypeName != null and terms.caseTypeName !=''">
                     and a.case_type_name = #{terms.caseTypeName}
@@ -349,20 +358,69 @@
                     and (DATE_FORMAT(b.file_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ >= ]]> #{terms.fileStart}
                     and DATE_FORMAT(b.file_time,'%Y-%m-%d %H:%i:%s') <![CDATA[ <= ]]> #{terms.fileEnd})
                 </if>
-                <if test="terms.queProv != null and terms.queProv !=''">
-                    and a.que_prov = #{terms.queProv}
+                <if test='terms.queCity != null and terms.queCity !="" and terms.statistics != null and terms.areaType == "1"'>
+                    and (b.mediate_unit_id is not null and c.city = #{terms.queCity}
+                    <if test="terms.unitGrades != null and terms.unitGrades.size > 0">
+                        and c.unit_grade in
+                        <foreach collection="terms.unitGrades" item="unitGrade" index="index" open="(" separator="," close=")">
+                            #{unitGrade}
+                        </foreach>
+                    </if>
+                    )
                 </if>
-                <if test="terms.queCity != null and terms.queCity !=''">
-                    and a.que_city = #{terms.queCity}
+                <if test='terms.queCity != null and terms.queCity !="" and terms.statistics != null and terms.areaType != "1"'>
+                    and ((b.mediate_unit_id is not null and c.city = #{terms.queCity}
+                    <if test="terms.unitGrades != null and terms.unitGrades.size > 0">
+                        and c.unit_grade in
+                        <foreach collection="terms.unitGrades" item="unitGrade" index="index" open="(" separator=","
+                                 close=")">
+                            #{unitGrade}
+                        </foreach>
+                    </if>)
+                    or (b.mediate_unit_id is null and a.que_city = #{terms.queCity})
+                    )
                 </if>
-                <if test="terms.queArea != null and terms.queArea !=''">
-                    and a.que_area = #{terms.queArea}
+                <if test='terms.queArea != null and terms.queArea !="" and terms.statistics != null and terms.areaType == "2"'>
+                    and (b.mediate_unit_id is not null and c.area = #{terms.queArea}
+                    <if test="terms.unitGrades != null and terms.unitGrades.size > 0">
+                        and c.unit_grade in
+                        <foreach collection="terms.unitGrades" item="unitGrade" index="index" open="(" separator="," close=")">
+                            #{unitGrade}
+                        </foreach>
+                    </if>
+                    )
                 </if>
-                <if test="terms.queRoad != null and terms.queRoad !=''">
-                    and a.que_road = #{terms.queRoad}
+                <if test='terms.queArea != null and terms.queArea !="" and terms.statistics != null and terms.areaType != "2"'>
+                    and ((b.mediate_unit_id is not null and c.area = #{terms.queArea}
+                    <if test="terms.unitGrades != null and terms.unitGrades.size > 0">
+                        and c.unit_grade in
+                        <foreach collection="terms.unitGrades" item="unitGrade" index="index" open="(" separator="," close=")">
+                            #{unitGrade}
+                        </foreach>
+                    </if>
+                    )
+                    or (b.mediate_unit_id is null and a.que_area = #{terms.queArea})
+                    )
+                </if>
+                <if test="terms.queRoad != null and terms.queRoad !='' and terms.statistics != null">
+                    and ((b.mediate_unit_id is not null and c.road = #{terms.queRoad}
+                    <if test="terms.unitGrades != null and terms.unitGrades.size > 0">
+                        and c.unit_grade in
+                        <foreach collection="terms.unitGrades" item="unitGrade" index="index" open="(" separator="," close=")">
+                            #{unitGrade}
+                        </foreach>
+                    </if>
+                    )
+                    or (b.mediate_unit_id is null and a.que_road = #{terms.queRoad}))
                 </if>
                 <if test="terms.isArea != null and terms.isArea !=''">
                     and a.que_city is not null and a.que_area is not null and a.que_road is not null
+                </if>
+                <if test="terms.queArea != null and terms.queArea !='' and terms.statistics == null">
+                    and a.que_area = #{terms.queArea}
+                </if>
+                <if test="terms.queRoad != null and terms.queRoad !='' and terms.statistics == null">
+                    and a.que_road = #{terms.queRoad}
                 </if>
                 <if test="terms.caseRef != null and terms.caseRef !=''">
                     and a.case_ref = #{terms.caseRef}
@@ -835,41 +893,38 @@
     <!--  统计分析(区域)  -->
     <select id="statisticsArea" resultType="cn.huge.module.cases.domain.dto.CaseStatisticsAreaDTO">
         SELECT
-        <if test="terms.areaType == null or terms.areaType ==''">
-            a.que_area as areaCode,a.que_area_name as areaName,
-        </if>
-        <if test='terms.areaType != null and terms.areaType =="1"'>
-            a.que_area as areaCode,a.que_area_name as areaName,
+        <if test='terms.areaType == null or terms.areaType =="1"'>
+            IF(c.area is null,a.que_city,c.city) as areaCode,IF(c.city_name is null,a.que_city_name,c.city_name) as areaName,
         </if>
         <if test='terms.areaType != null and terms.areaType =="2"'>
-            a.que_road as areaCode,a.que_road_name as areaName,
+            IF(c.area is null,a.que_area,c.area) as areaCode,IF(c.area_name is null,a.que_area_name,c.area_name) as areaName,
         </if>
+        <if test='terms.areaType != null and terms.areaType =="3"'>
+            IF(c.road is null,a.que_road,c.road) as areaCode,IF(c.road_name is null,a.que_road_name,c.road_name) as areaName,
+        </if>
+        <if test='terms.areaType != null and terms.areaType =="4"'>
+            IF(c.road is null,a.que_road,c.road) as areaCode,IF(c.road_name is null,a.que_road_name,c.road_name) as areaName,
+        </if>
+        c.unit_grade as unitGrade,
         count(1) as caseNum,
-        sum(case when b.medi_result = '22_00025-1' then 1 else 0 end) as resolveNum,
-        sum(case when b.medi_result is null and a.info_process <![CDATA[ < ]]> 4 then 1 else 0 end) as resolveingNum,
-        sum(case when b.medi_result = '22_00025-2' then 1 else 0 end) as unResolveNum,
+        sum(case when b.medi_result = '22_00025-1' and a.info_process = 3 then 1 else 0 end) as resolveNum,
+        sum(case when a.info_process <![CDATA[ < ]]> 3 then 1 else 0 end) as resolveingNum,
+        sum(case when b.medi_result = '22_00025-2' and a.info_process = 3 then 1 else 0 end) as unResolveNum,
         sum(case when a.info_process = 4 then 1 else 0 end) as rejectNum
         FROM
-        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
+        dyh_case_info a
+        inner JOIN dyh_case_info_unfold b on a.id = b.id
+        LEFT JOIN dyh_ct_unit c ON b.mediate_unit_id = c.id
         <include refid="where-part-all"/>
-        <if test="terms.areaType == null or terms.areaType ==''">
-            group by a.que_area
-        </if>
-        <if test='terms.areaType != null and terms.areaType =="1"'>
-            group by a.que_area
-        </if>
-        <if test='terms.areaType != null and terms.areaType =="2"'>
-            group by a.que_road
-        </if>
-
+        group by areaCode
     </select>
     <!--  统计分析(基础)  -->
     <select id="statisticsBase" resultType="cn.huge.module.cases.domain.dto.CaseStatisticsBaseDTO">
         SELECT
         count(1) as totalNum,
-        sum(case when b.medi_result = '22_00025-1' then 1 else 0 end) as resolveNum,
-        sum(case when b.medi_result is null and a.info_process <![CDATA[ < ]]> 4 then 1 else 0 end) as resolveingNum,
-        sum(case when b.medi_result = '22_00025-2' then 1 else 0 end) as unResolveNum,
+        sum(case when b.medi_result = '22_00025-1' and a.info_process = 3 then 1 else 0 end) as resolveNum,
+        sum(case when a.info_process <![CDATA[ < ]]> 3 then 1 else 0 end) as resolveingNum,
+        sum(case when b.medi_result = '22_00025-2' and a.info_process = 3 then 1 else 0 end) as unResolveNum,
         sum(case when a.case_level = 1 then 1 else 0 end) as oneLevelNum,
         sum(case when a.case_level = 2 then 1 else 0 end) as twoLevelNum,
         sum(case when a.case_level = 3 then 1 else 0 end) as threeLevelNum,
@@ -877,15 +932,31 @@
         sum(case when a.info_process = 3 then 1 else 0 end) as finishNum,
         sum(case when a.info_process = 4 then 1 else 0 end) as rejectNum
         FROM
-        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
+        dyh_case_info a
+        inner JOIN dyh_case_info_unfold b on a.id = b.id
+        LEFT JOIN dyh_ct_unit c ON b.mediate_unit_id = c.id
         <include refid="where-part-all"/>
     </select>
+    <!--  统计分析(类型)  -->
+    <select id="statisticsTypeFirst" resultType="cn.huge.module.cases.domain.dto.CaseStatisticsTypeDTO">
+        SELECT
+        a.case_type_first as caseType,a.case_type_first_name as caseTypeName,count(1) as caseNum
+        FROM
+        dyh_case_info a
+        inner JOIN dyh_case_info_unfold b on a.id = b.id
+        LEFT JOIN dyh_ct_unit c ON b.mediate_unit_id = c.id
+        <include refid="where-part-all"/>
+        group by a.case_type_first
+    </select>
+
     <!--  统计分析(类型)  -->
     <select id="statisticsType" resultType="cn.huge.module.cases.domain.dto.CaseStatisticsTypeDTO">
         SELECT
         a.case_type as caseType,a.case_type_name as caseTypeName,count(1) as caseNum
         FROM
-        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
+        dyh_case_info a
+        inner JOIN dyh_case_info_unfold b on a.id = b.id
+        LEFT JOIN dyh_ct_unit c ON b.mediate_unit_id = c.id
         <include refid="where-part-all"/>
         group by a.case_type
     </select>
@@ -894,12 +965,14 @@
     <select id="statisticsSource" resultType="cn.huge.module.cases.domain.dto.CaseStatisticsSourceDTO">
         SELECT
         a.canal,a.canal_name as canalName,count(1) as caseNum,
-        sum(case when b.medi_result = '22_00025-1' then 1 else 0 end) as resolveNum,
-        sum(case when b.medi_result is null and a.info_process <![CDATA[ < ]]> 4 then 1 else 0 end) as resolveingNum,
-        sum(case when b.medi_result = '22_00025-2' then 1 else 0 end) as unResolveNum,
+        sum(case when b.medi_result = '22_00025-1' and a.info_process = 3 then 1 else 0 end) as resolveNum,
+        sum(case when a.info_process <![CDATA[ < ]]> 3 then 1 else 0 end) as resolveingNum,
+        sum(case when b.medi_result = '22_00025-2' and a.info_process = 3 then 1 else 0 end) as unResolveNum,
         sum(case when a.info_process = 4 then 1 else 0 end) as rejectNum
         FROM
-        dyh_case_info a LEFT JOIN dyh_case_info_unfold b on a.id = b.id
+        dyh_case_info a
+        inner JOIN dyh_case_info_unfold b on a.id = b.id
+        LEFT JOIN dyh_ct_unit c ON b.mediate_unit_id = c.id
         <include refid="where-part-all"/>
         group by a.canal
     </select>

--
Gitblit v1.8.0