123 lines
5.6 KiB
XML
123 lines
5.6 KiB
XML
<?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.ruoyi.system.mapper.DutyConfigMapper">
|
|
|
|
<resultMap type="DutyConfig" id="DutyConfigResult">
|
|
<result property="id" column="id" />
|
|
<result property="configName" column="config_name" />
|
|
<result property="startTime" column="start_time" />
|
|
<result property="endTime" column="end_time" />
|
|
<result property="status" column="status" />
|
|
<result property="remark" column="remark" />
|
|
<result property="createBy" column="create_by" />
|
|
<result property="createTime" column="create_time" />
|
|
<result property="updateBy" column="update_by" />
|
|
<result property="updateTime" column="update_time" />
|
|
<result property="delFlag" column="del_flag" />
|
|
<collection property="dutyUsers" ofType="DutyUser" column="id" select="com.ruoyi.system.mapper.DutyUserMapper.selectDutyUsersByConfigIdOrderBySort"/>
|
|
</resultMap>
|
|
|
|
<sql id="selectDutyConfigVo">
|
|
select id, config_name, start_time, end_time, status, remark, create_by, create_time, update_by, update_time, del_flag from duty_config
|
|
</sql>
|
|
|
|
<select id="selectDutyConfigList" parameterType="DutyConfig" resultMap="DutyConfigResult">
|
|
<include refid="selectDutyConfigVo"/>
|
|
<where>
|
|
del_flag = '0'
|
|
<if test="configName != null and configName != ''"> and config_name like concat('%', #{configName}, '%')</if>
|
|
<if test="startTime != null "> and start_time = #{startTime}</if>
|
|
<if test="endTime != null "> and end_time = #{endTime}</if>
|
|
<if test="status != null and status != ''"> and status = #{status}</if>
|
|
<if test="params.beginTime != null and params.beginTime != ''"><!-- 开始时间检索 -->
|
|
AND date_format(create_time,'%y%m%d') >= date_format(#{params.beginTime},'%y%m%d')
|
|
</if>
|
|
<if test="params.endTime != null and params.endTime != ''"><!-- 结束时间检索 -->
|
|
AND date_format(create_time,'%y%m%d') <= date_format(#{params.endTime},'%y%m%d')
|
|
</if>
|
|
</where>
|
|
order by create_time desc
|
|
</select>
|
|
|
|
<select id="selectDutyConfigById" parameterType="Long" resultMap="DutyConfigResult">
|
|
<include refid="selectDutyConfigVo"/>
|
|
where id = #{id}
|
|
</select>
|
|
|
|
<select id="selectActiveDutyConfig" parameterType="java.util.Date" resultMap="DutyConfigResult">
|
|
<include refid="selectDutyConfigVo"/>
|
|
where status = '1'
|
|
and del_flag = '0'
|
|
and #{currentTime} between start_time and end_time
|
|
order by create_time desc
|
|
limit 1
|
|
</select>
|
|
|
|
<select id="checkTimeConflict" resultType="int">
|
|
select count(1) from duty_config
|
|
where status = '1'
|
|
and del_flag = '0'
|
|
and (
|
|
(#{startTime} between start_time and end_time)
|
|
or (#{endTime} between start_time and end_time)
|
|
or (start_time between #{startTime} and #{endTime})
|
|
or (end_time between #{startTime} and #{endTime})
|
|
)
|
|
<if test="excludeId != null">
|
|
and id != #{excludeId}
|
|
</if>
|
|
</select>
|
|
|
|
<insert id="insertDutyConfig" parameterType="DutyConfig" useGeneratedKeys="true" keyProperty="id">
|
|
insert into duty_config
|
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
|
<if test="configName != null and configName != ''">config_name,</if>
|
|
<if test="startTime != null">start_time,</if>
|
|
<if test="endTime != null">end_time,</if>
|
|
<if test="status != null">status,</if>
|
|
<if test="remark != null">remark,</if>
|
|
<if test="createBy != null">create_by,</if>
|
|
<if test="delFlag != null">del_flag,</if>
|
|
create_time
|
|
</trim>
|
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
|
<if test="configName != null and configName != ''">#{configName},</if>
|
|
<if test="startTime != null">#{startTime},</if>
|
|
<if test="endTime != null">#{endTime},</if>
|
|
<if test="status != null">#{status},</if>
|
|
<if test="remark != null">#{remark},</if>
|
|
<if test="createBy != null">#{createBy},</if>
|
|
<if test="delFlag != null">#{delFlag},</if>
|
|
sysdate()
|
|
</trim>
|
|
</insert>
|
|
|
|
<update id="updateDutyConfig" parameterType="DutyConfig">
|
|
update duty_config
|
|
<trim prefix="SET" suffixOverrides=",">
|
|
<if test="configName != null and configName != ''">config_name = #{configName},</if>
|
|
<if test="startTime != null">start_time = #{startTime},</if>
|
|
<if test="endTime != null">end_time = #{endTime},</if>
|
|
<if test="status != null">status = #{status},</if>
|
|
<if test="remark != null">remark = #{remark},</if>
|
|
<if test="updateBy != null">update_by = #{updateBy},</if>
|
|
<if test="delFlag != null">del_flag = #{delFlag},</if>
|
|
update_time = sysdate()
|
|
</trim>
|
|
where id = #{id}
|
|
</update>
|
|
|
|
<delete id="deleteDutyConfigById" parameterType="Long">
|
|
update duty_config set del_flag = '1' where id = #{id}
|
|
</delete>
|
|
|
|
<delete id="deleteDutyConfigByIds" parameterType="java.lang.String">
|
|
update duty_config set del_flag = '1' where id in
|
|
<foreach item="id" collection="array" open="(" separator="," close=")">
|
|
#{id}
|
|
</foreach>
|
|
</delete>
|
|
|
|
</mapper> |