| <?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.dsh.competition.mapper.CompetitionMapper"> | 
|   | 
|   | 
|     <select id="queryCompetitionList" resultType="com.dsh.competition.model.CompetitionListVo"> | 
|         select * from ( | 
|             select | 
|             a.id, | 
|             a.`name`, | 
|             a.coverDrawing, | 
|             a.city as cityName, | 
|             a.registerCondition, | 
|             a.introduction, | 
|             DATE_FORMAT(a.registerEndTime, '%Y-%m-%d %H:%i') as registerEndTime, | 
|             CONCAT(a.startAge, '-', a.endAge) as age, | 
|             a.baseNumber + a.applicantsNumber as heat | 
|             from t_competition a | 
|             where a.auditStatus = 2 and a.`status` = 2 and a.state = 1 | 
|             <if test="null != cityCode and '' != cityCode"> | 
|                 and a.cityCode = #{cityCode} | 
|             </if> | 
|             <if test="null != content and '' != content"> | 
|                 and a.name like CONCAT('%', #{content}, '%') | 
|             </if> | 
|             <if test="null != registerCondition"> | 
|                 and a.registerCondition = #{registerCondition} | 
|             </if> | 
|             order by a.insertTime desc | 
|         ) as aa | 
|         <if test="null != heat and '' != heat"> | 
|             order by aa.heat #{heat} | 
|         </if> | 
|     </select> | 
|   | 
|   | 
|     <update id="taskSetStatusStart"> | 
|         update t_competition set status = 2 where status = 1 and state = 1 and auditStatus = 2 and now() between startTime and endTime | 
|     </update> | 
|   | 
|   | 
|     <update id="taskSetStatusEnd"> | 
|         update t_competition set status = 3 where status = 2 and state = 1 and auditStatus = 2 and now() >= endTime | 
|     </update> | 
| </mapper> |