From 5b76d629eef02be2f8c7c8ccde13d02aee25e63b Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期三, 18 九月 2024 16:17:54 +0800 Subject: [PATCH] 大屏优化 --- ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml | 212 ++++++++++++++++++++++++++++++++++++++++++---------- 1 files changed, 171 insertions(+), 41 deletions(-) diff --git a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml index 5154ce6..45b4d2f 100644 --- a/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml +++ b/ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml @@ -1,65 +1,82 @@ <?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="publishId" column="publish_id" /> - <result property="ruleId" column="rule_id" /> - <result property="examineCategory" column="examine_category" /> - <result property="createTime" column="create_time" /> - <result property="updateUser" column="update_user" /> - <result property="updateUserName" column="update_user_name" /> - <result property="auditState" column="audit_state" /> + <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, dept_id, publish_id, rule_id, examine_category, create_time, update_user, update_user_name, audit_state from t_check_score + 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="deptId != null "> and dept_id = #{deptId}</if> - <if test="publishId != null "> and publish_id = #{publishId}</if> - <if test="ruleId != null "> and rule_id = #{ruleId}</if> - <if test="examineCategory != null "> and examine_category = #{examineCategory}</if> + <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> + ${params.dataScope} </where> + order by create_time desc </select> - - <select id="selectCheckScoreById" resultMap="CheckScoreResult"> + + <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=","> <if test="score != null">score,</if> <if test="deptId != null">dept_id,</if> - <if test="publishId != null">publish_id,</if> - <if test="ruleId != null">rule_id,</if> + <if test="templateId != null">template_id,</if> + <if test="examineTag != null">examine_tag,</if> <if test="examineCategory != null">examine_category,</if> <if test="createTime != null">create_time,</if> + <if test="updateTime != null">update_time,</if> <if test="updateUser != null">update_user,</if> - <if test="updateUserName != null">update_user_name,</if> - <if test="auditState != null">audit_state,</if> - </trim> + <if test="publish != null">publish,</if> + </trim> <trim prefix="values (" suffix=")" suffixOverrides=","> <if test="score != null">#{score},</if> <if test="deptId != null">#{deptId},</if> - <if test="publishId != null">#{publishId},</if> - <if test="ruleId != null">#{ruleId},</if> + <if test="templateId != null">#{templateId},</if> + <if test="examineTag != null">#{examineTag},</if> <if test="examineCategory != null">#{examineCategory},</if> <if test="createTime != null">#{createTime},</if> + <if test="updateTime != null">#{updateTime},</if> <if test="updateUser != null">#{updateUser},</if> - <if test="updateUserName != null">#{updateUserName},</if> - <if test="auditState != null">#{auditState},</if> - </trim> + <if test="publish != null">#{publish},</if> + </trim> </insert> <update id="updateCheckScore"> @@ -67,25 +84,138 @@ <trim prefix="SET" suffixOverrides=","> <if test="score != null">score = #{score},</if> <if test="deptId != null">dept_id = #{deptId},</if> - <if test="publishId != null">publish_id = #{publishId},</if> - <if test="ruleId != null">rule_id = #{ruleId},</if> + <if test="templateId != null">template_id = #{templateId},</if> + <if test="examineTag != null">examine_tag = #{examineTag},</if> <if test="examineCategory != null">examine_category = #{examineCategory},</if> <if test="createTime != null">create_time = #{createTime},</if> + <if test="updateTime != null">update_time = #{updateTime},</if> <if test="updateUser != null">update_user = #{updateUser},</if> - <if test="updateUserName != null">update_user_name = #{updateUserName},</if> - <if test="auditState != null">audit_state = #{auditState},</if> + <if test="publish != null">publish = #{publish},</if> </trim> where id = #{id} </update> - <delete id="deleteCheckScoreById" > - delete from t_check_score where id = #{id} + <delete id="deleteCheckScoreById" parameterType="Long"> + delete + from t_check_score + where id = #{id} </delete> - <delete id="deleteCheckScoreByIds" > - delete from t_check_score where id in + <delete id="deleteCheckScoreByIds" parameterType="String"> + delete from t_check_score where id in <foreach item="id" collection="array" open="(" separator="," close=")"> #{id} </foreach> </delete> -</mapper> \ No newline at end of file + + <update id="publishCheckScore"> + update t_check_score set publish = #{publish},update_time =#{updateTime},update_user= #{updateUser} where id in + <foreach collection="id" item="id" open="(" close=")" separator=","> + #{id} + </foreach> + </update> + + <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="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,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 * 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> + examine_tag = #{examineTag} + 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> + + <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 + ORDER BY cs.create_time DESC + ]]> + </select> + + <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> + + <select id="dashboard" resultType="com.ycl.platform.domain.entity.CheckScore"> + select s.*,d.area as deptName from t_check_score s + left join sys_dept d on s.dept_id = d.dept_id + <where> + <if test="dataScope == 1"> + AND s.examine_tag = 1 + </if> + </where> + ORDER BY + s.create_time DESC + LIMIT 7 + </select> +</mapper> -- Gitblit v1.8.0