<?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">
|
<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"/>
|
</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
|
</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>
|
${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=",">
|
<if test="score != null">score,</if>
|
<if test="deptId != null">dept_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="publish != null">publish,</if>
|
</trim>
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
<if test="score != null">#{score},</if>
|
<if test="deptId != null">#{deptId},</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="publish != null">#{publish},</if>
|
</trim>
|
</insert>
|
|
<update id="updateCheckScore">
|
update t_check_score
|
<trim prefix="SET" suffixOverrides=",">
|
<if test="score != null">score = #{score},</if>
|
<if test="deptId != null">dept_id = #{deptId},</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="publish != null">publish = #{publish},</if>
|
</trim>
|
where id = #{id}
|
</update>
|
|
<delete id="deleteCheckScoreById" parameterType="Long">
|
delete
|
from t_check_score
|
where id = #{id}
|
</delete>
|
|
<delete id="deleteCheckScoreByIds" parameterType="String">
|
delete from t_check_score where id in
|
<foreach item="id" collection="array" open="(" separator="," close=")">
|
#{id}
|
</foreach>
|
</delete>
|
|
<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>
|
|
</mapper>
|