zxl
19 小时以前 0d243e7f5dc593cdc6e0608bb52cd635f8fc6982
ycl-server/src/main/resources/mapper/zgyw/CheckScoreMapper.xml
@@ -144,24 +144,25 @@
    </insert>
    <select id="selectCheckScoreMap" resultType="com.ycl.platform.domain.entity.CheckScore">
        SELECT
        id,
        SELECT * FROM
        (SELECT
        tcs.id,
        tcs.dept_id,
        examine_category,
        ROUND(AVG(score) OVER(PARTITION BY tcs.dept_id, examine_category), 2) AS score,
        tcs.examine_category,
        tcs.publish,
        tcs.create_time AS createTime
        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_FORMAT(tcs.create_time, '%Y-%m') BETWEEN DATE_FORMAT(#{startDate}, '%Y-%m') AND
            DATE_FORMAT(#{endDate}, '%Y-%m')
            <if test="params.publish != null  and params.publish != ''">and publish = #{params.publish}</if>
            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>
        GROUP BY tcs.dept_id, tcs.examine_category, tcs.examine_tag
        ) t where rn =1
    </select>
    <select id="getLast" resultType="com.ycl.platform.domain.entity.CheckScore">
@@ -179,21 +180,21 @@
               d.area,
               CASE
                   WHEN cs.examine_tag = '0' THEN '省厅'
                   WHEN cs.examine_tag = '1' 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
        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)) AS score
               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
@@ -205,4 +206,26 @@
        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>