From 6c5d7fa4635b06d30840c39f96bd381b65cb56e7 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期二, 03 九月 2024 19:43:59 +0800
Subject: [PATCH] 数据中心优化

---
 ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml |   67 ++++++++++++++++++++++++++-------
 1 files changed, 53 insertions(+), 14 deletions(-)

diff --git a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
index 0efeca1..de53afb 100644
--- a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
+++ b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
@@ -3,7 +3,7 @@
 PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
 <mapper namespace="com.ycl.platform.mapper.CheckScoreMapper">
-    
+
     <resultMap type="com.ycl.platform.domain.entity.CheckScore" id="CheckScoreResult">
         <result property="id"    column="id"    />
         <result property="score"    column="score"    />
@@ -35,13 +35,14 @@
             <if test="deptId != null "> and tcs.dept_id = #{deptId}</if>
             ${params.dataScope}
         </where>
+        order by create_time desc
     </select>
-    
+
     <select id="selectCheckScoreById" parameterType="Long" resultMap="CheckScoreResult">
         <include refid="selectCheckScoreVo"/>
         where id = #{id}
     </select>
-        
+
     <insert id="insertCheckScore" useGeneratedKeys="true" keyProperty="id">
         insert into t_check_score
         <trim prefix="(" suffix=")" suffixOverrides=",">
@@ -89,7 +90,7 @@
     </delete>
 
     <delete id="deleteCheckScoreByIds" parameterType="String">
-        delete from t_check_score where id in 
+        delete from t_check_score where id in
         <foreach item="id" collection="array" open="(" separator="," close=")">
             #{id}
         </foreach>
@@ -105,7 +106,16 @@
     <select id="selectScoreIndex" resultType="java.util.Map">
         select t.* from ${tableName} t
         left join sys_dept d on t.dept_id = d.dept_id
-        where t.dept_id =#{deptId} and date_format(t.create_time,'%Y-%m')  = #{date}
+        where t.dept_id = #{deptId}
+        <if test="examineTag != null">
+            and examine_tag = #{examineTag}
+        </if>
+        <if test="date != null">
+            and date_format(t.create_time,'%Y-%m') = #{date}
+        </if>
+        <if test="quarter != null and quarter.size > 0">
+            and date_format(t.create_time, '%Y-%m') between #{quarter[0]} and #{quarter[1]}
+        </if>
         ${params.dataScope}
     </select>
 
@@ -117,21 +127,50 @@
 
     <select id="selectCheckScoreMap" resultType="com.ycl.platform.domain.entity.CheckScore">
         SELECT
+            id,
             tcs.dept_id,
             examine_category,
-            ROUND(AVG(score), 2) AS score,
-            #{startDate} AS startDate,
-            #{endDate} AS endDate,
-            ANY_VALUE(tcs.create_time) AS createTime
+            ROUND(AVG(score) OVER(PARTITION BY tcs.dept_id, examine_category), 2) AS score,
+            tcs.create_time AS createTime
         FROM
             t_check_score tcs
                 LEFT JOIN sys_dept d ON tcs.dept_id = d.dept_id
         WHERE
             examine_tag = #{examineTag}
-          AND tcs.create_time BETWEEN #{startDate} AND #{endDate}
-        GROUP BY
-            tcs.dept_id,
-            examine_category
+          AND DATE_FORMAT(tcs.create_time, '%Y-%m') BETWEEN DATE_FORMAT(#{startDate}, '%Y-%m') AND DATE_FORMAT(#{endDate}, '%Y-%m')
+        GROUP BY tcs.dept_id, examine_category,examine_tag
+</select>
+
+    <select id="home" resultType="java.util.Map">
+        <![CDATA[
+        SELECT
+            DATE_FORMAT(cs.create_time, '%Y-%m-%d %h:%i:%s') AS createTime,
+            d.area,
+            CASE WHEN cs.examine_tag = '0' THEN '鐪佸巺' WHEN cs.examine_tag = '1' THEN '甯傚眬' WHEN cs.examine_tag = '2' THEN '' END AS examineTag,
+            ct.template_name AS templateName,
+            cs.score
+        FROM
+            t_check_score cs
+                LEFT JOIN t_check_template ct ON cs.template_id = ct.id
+                LEFT JOIN sys_dept d ON cs.dept_id = d.dept_id
+        WHERE cs.score < ct.alarm_score
+        ORDER BY cs.create_time DESC
+        ]]>
     </select>
 
-</mapper>
\ No newline at end of file
+    <select id="calculate" resultType="java.util.Map">
+        SELECT
+            area AS deptName,
+            ROUND(AVG(score)) AS score
+        FROM
+            t_check_score tcs
+                LEFT JOIN sys_dept d ON tcs.dept_id = d.dept_id
+        WHERE
+            examine_tag = 1
+          AND examine_category = #{category}
+          AND DATE_FORMAT(tcs.create_time, '%Y-%m') BETWEEN DATE_FORMAT(#{startDate}, '%Y-%m') AND DATE_FORMAT(#{endDate}, '%Y-%m')
+        GROUP BY tcs.dept_id
+        ORDER BY score DESC, tcs.dept_id
+    </select>
+
+</mapper>

--
Gitblit v1.8.0