From c83101eb62f5d4906b9c01ceea6b21a37f9e84d8 Mon Sep 17 00:00:00 2001
From: zxl <763096477@qq.com>
Date: 星期二, 18 十一月 2025 09:24:53 +0800
Subject: [PATCH] bug修复
---
ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml | 196 ++++++++++++++++++++++++++++++++++++-------------
1 files changed, 144 insertions(+), 52 deletions(-)
diff --git a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
index ae68b76..33bfe57 100644
--- a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
+++ b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
@@ -1,47 +1,58 @@
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
-PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
-"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+ 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" />
- <result property="deptId" column="dept_id" />
- <result property="templateId" column="template_id" />
- <result property="examineTag" column="examine_tag" />
- <result property="examineCategory" column="examine_category" />
- <result property="createTime" column="create_time" />
- <result property="updateTime" column="update_time" />
- <result property="updateUser" column="update_user" />
- <result property="publish" column="publish" />
+ <result property="id" column="id"/>
+ <result property="score" column="score"/>
+ <result property="deptId" column="dept_id"/>
+ <result property="templateId" column="template_id"/>
+ <result property="examineTag" column="examine_tag"/>
+ <result property="examineCategory" column="examine_category"/>
+ <result property="createTime" column="create_time"/>
+ <result property="updateTime" column="update_time"/>
+ <result property="updateUser" column="update_user"/>
+ <result property="publish" column="publish"/>
</resultMap>
<sql id="selectCheckScoreVo">
- select id, score, tcs.dept_id, template_id, examine_tag, examine_category, tcs.create_time,tcs.update_time,tcs.update_user, publish
- from t_check_score tcs left join sys_dept d on tcs.dept_id = d.dept_id
+ select id,
+ score,
+ tcs.dept_id,
+ template_id,
+ examine_tag,
+ examine_category,
+ tcs.create_time,
+ tcs.update_time,
+ tcs.update_user,
+ publish
+ from t_check_score tcs
+ left join sys_dept d on tcs.dept_id = d.dept_id
</sql>
<select id="selectCheckScoreList" resultMap="CheckScoreResult">
<include refid="selectCheckScoreVo"/>
<where>
- <if test="score != null "> and score = #{score}</if>
- <if test="templateId != null "> and template_id = #{templateId}</if>
- <if test="createTime != null "> and DATE(tcs.create_time) = #{createTime}</if>
- <if test="date != null "> and date_format(tcs.create_time,'%Y-%m') = #{date}</if>
- <if test="examineTag != null "> and examine_tag = #{examineTag}</if>
- <if test="examineCategory != null "> and examine_category = #{examineCategory}</if>
- <if test="params.publish != null and params.publish != ''"> and publish = #{params.publish}</if>
- <if test="deptId != null "> and tcs.dept_id = #{deptId}</if>
+ <if test="score != null ">and score = #{score}</if>
+ <if test="templateId != null ">and template_id = #{templateId}</if>
+ <if test="createTime != null ">and DATE(tcs.create_time) = #{createTime}</if>
+ <if test="date != null ">and date_format(tcs.create_time,'%Y-%m') = #{date}</if>
+ <if test="examineTag != null ">and examine_tag = #{examineTag}</if>
+ <if test="examineCategory != null ">and examine_category = #{examineCategory}</if>
+ <if test="params.publish != null and params.publish != ''">and publish = #{params.publish}</if>
+ <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=",">
@@ -54,7 +65,7 @@
<if test="updateTime != null">update_time,</if>
<if test="updateUser != null">update_user,</if>
<if test="publish != null">publish,</if>
- </trim>
+ </trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="score != null">#{score},</if>
<if test="deptId != null">#{deptId},</if>
@@ -65,10 +76,10 @@
<if test="updateTime != null">#{updateTime},</if>
<if test="updateUser != null">#{updateUser},</if>
<if test="publish != null">#{publish},</if>
- </trim>
+ </trim>
</insert>
- <update id="updateCheckScore" >
+ <update id="updateCheckScore">
update t_check_score
<trim prefix="SET" suffixOverrides=",">
<if test="score != null">score = #{score},</if>
@@ -85,11 +96,13 @@
</update>
<delete id="deleteCheckScoreById" parameterType="Long">
- delete from t_check_score where id = #{id}
+ delete
+ from t_check_score
+ where id = #{id}
</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,35 +118,114 @@
<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}
- <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}
+ <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>
+ <if test="params.publish != null and params.publish != ''">
+ and publish = #{params.publish}
+ </if>
+ ${params.dataScope}
+ </where>
</select>
<insert id="saveBatch">
- insert into t_check_score (score,dept_id,template_id,examine_tag,examine_category,create_time) values <foreach collection="scoreList" separator="," item="score">
- (#{score.score},#{score.deptId},#{score.templateId},#{score.examineTag},#{score.examineCategory},#{score.createTime})
- </foreach>
+ insert into t_check_score (score,dept_id,template_id,index_id,examine_tag,examine_category,create_time) values
+ <foreach collection="scoreList" separator="," item="score">
+ (#{score.score},#{score.deptId},#{score.templateId},#{score.indexId},#{score.examineTag},#{score.examineCategory},#{score.createTime})
+ </foreach>
</insert>
<select id="selectCheckScoreMap" resultType="com.ycl.platform.domain.entity.CheckScore">
- SELECT
- id,
- tcs.dept_id,
- examine_category,
- ROUND(AVG(score) OVER(PARTITION BY tcs.dept_id, examine_category), 2) AS score,
- tcs.create_time AS createTime
+ SELECT * FROM
+ (SELECT
+ tcs.id,
+ tcs.dept_id,
+ tcs.examine_category,
+ tcs.publish,
+ tcs.create_time,
+ ROW_NUMBER() OVER(PARTITION BY tcs.dept_id, tcs.examine_category ORDER BY tcs.create_time DESC) AS rn,
+ AVG(tcs.score) OVER(PARTITION BY tcs.dept_id, tcs.examine_category) AS score
FROM
- t_check_score tcs
- LEFT JOIN sys_dept d ON tcs.dept_id = d.dept_id
- WHERE
+ t_check_score tcs
+ LEFT JOIN sys_dept d ON tcs.dept_id = d.dept_id
+ <where>
examine_tag = #{examineTag}
- AND DATE_FORMAT(tcs.create_time, '%Y-%m') BETWEEN DATE_FORMAT(#{startDate}, '%Y-%m') AND DATE_FORMAT(#{endDate}, '%Y-%m')
+ AND DATE(tcs.create_time) BETWEEN DATE(#{startDate}) AND DATE(#{endDate})
+ <if test="params.publish != null and params.publish != ''">AND tcs.publish = #{params.publish}</if>
+ ${params.dataScope}
+ </where>
+ ) t where rn =1
</select>
-</mapper>
\ No newline at end of file
+ <select id="getLast" resultType="com.ycl.platform.domain.entity.CheckScore">
+ select * from t_check_score tcs LEFT JOIN sys_dept d ON tcs.dept_id = d.dept_id
+ <where>
+ tcs.examine_tag = #{examineTag}
+ <if test="params.publish != null and params.publish != ''">and tcs.publish = #{params.publish}</if>
+ ${params.dataScope}
+ </where>
+ order by tcs.create_time desc limit 1
+ </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 and cs.create_time between #{startTime} and #{endTime}
+ ORDER BY cs.create_time DESC
+ ]]>
+ </select>
+
+ <select id="calculate" resultType="java.util.Map">
+ SELECT area AS deptName,
+ ROUND(AVG(score),2) 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>
+
+ <select id="dashboard" resultType="com.ycl.platform.domain.entity.CheckScore">
+ select score,d.area as deptName,s.examine_category from t_check_score s
+ left join sys_dept d on s.dept_id = d.dept_id
+ <where>
+ s.create_time between #{startTime} and #{endTime}
+ <if test="dataScope == 1">
+ AND s.examine_tag = 0
+ </if>
+ <if test="dataScope == 2">
+ AND s.examine_tag = 1
+ </if>
+ <if test="dataScope == 3">
+ AND s.examine_tag = 2
+ </if>
+ </where>
+ ORDER BY s.create_time DESC
+ </select>
+
+ <select id="selectToday" resultType="com.ycl.platform.domain.entity.CheckScore">
+ select * from t_check_score
+ where date(create_time) = #{day}
+ </select>
+</mapper>
--
Gitblit v1.8.0