131 lines
6.6 KiB
XML
131 lines
6.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.evo.personnelMatters.mapper.RzLeaveDetailMapper">
|
|
|
|
<resultMap type="RzLeaveDetail" id="RzLeaveDetailResult">
|
|
<result property="id" column="id" />
|
|
<result property="leaveId" column="leave_id" />
|
|
<result property="name" column="name" />
|
|
<result property="type" column="type" />
|
|
<result property="leaveStartTime" column="leave_start_time" />
|
|
<result property="leaveEndTime" column="leave_end_time" />
|
|
<result property="leaveHour" column="leave_hour" />
|
|
<result property="remarks" column="remarks" />
|
|
<result property="createTime" column="create_time" />
|
|
<result property="createBy" column="create_by" />
|
|
<result property="updateTime" column="update_time" />
|
|
<result property="updateBy" column="update_by" />
|
|
<result property="delFlag" column="del_flag" />
|
|
</resultMap>
|
|
|
|
<sql id="selectRzLeaveDetailVo">
|
|
select id, leave_id,name,type, leave_start_time, leave_end_time, leave_hour, remarks, create_time, create_by, update_time, update_by, del_flag from rz_leave_detail
|
|
</sql>
|
|
|
|
<select id="selectRzLeaveDetailList" parameterType="RzLeaveDetail" resultMap="RzLeaveDetailResult">
|
|
<include refid="selectRzLeaveDetailVo"/>
|
|
<where>
|
|
del_flag = '0'
|
|
<if test="name != null and name != ''"> and name like concat('%', #{name}, '%')</if>
|
|
<if test="leaveId != null "> and leave_id = #{leaveId}</if>
|
|
</where>
|
|
order by create_time desc
|
|
</select>
|
|
|
|
<select id="selectRzLeaveDetailById" parameterType="Long" resultMap="RzLeaveDetailResult">
|
|
<include refid="selectRzLeaveDetailVo"/>
|
|
where id = #{id}
|
|
</select>
|
|
|
|
<insert id="insertRzLeaveDetail" parameterType="RzLeaveDetail" useGeneratedKeys="true" keyProperty="id">
|
|
insert into rz_leave_detail
|
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
|
<if test="leaveId != null">leave_id,</if>
|
|
<if test="name != null">name,</if>
|
|
<if test="type != null">type,</if>
|
|
<if test="leaveStartTime != null">leave_start_time,</if>
|
|
<if test="leaveEndTime != null">leave_end_time,</if>
|
|
<if test="leaveHour != null">leave_hour,</if>
|
|
<if test="remarks != null">remarks,</if>
|
|
<if test="createTime != null">create_time,</if>
|
|
<if test="createBy != null">create_by,</if>
|
|
<if test="updateTime != null">update_time,</if>
|
|
<if test="updateBy != null">update_by,</if>
|
|
<if test="delFlag != null">del_flag,</if>
|
|
</trim>
|
|
<trim prefix="values (" suffix=")" suffixOverrides=",">
|
|
<if test="leaveId != null">#{leaveId},</if>
|
|
<if test="name != null">#{name},</if>
|
|
<if test="type != null">#{type},</if>
|
|
<if test="leaveStartTime != null">#{leaveStartTime},</if>
|
|
<if test="leaveEndTime != null">#{leaveEndTime},</if>
|
|
<if test="leaveHour != null">#{leaveHour},</if>
|
|
<if test="remarks != null">#{remarks},</if>
|
|
<if test="createTime != null">#{createTime},</if>
|
|
<if test="createBy != null">#{createBy},</if>
|
|
<if test="updateTime != null">#{updateTime},</if>
|
|
<if test="updateBy != null">#{updateBy},</if>
|
|
<if test="delFlag != null">#{delFlag},</if>
|
|
</trim>
|
|
</insert>
|
|
|
|
<update id="updateRzLeaveDetail" parameterType="RzLeaveDetail">
|
|
update rz_leave_detail
|
|
<trim prefix="SET" suffixOverrides=",">
|
|
<if test="name != null">name = #{name},</if>
|
|
<if test="type != null">type = #{type},</if>
|
|
<if test="leaveStartTime != null">leave_start_time = #{leaveStartTime},</if>
|
|
<if test="leaveEndTime != null">leave_end_time = #{leaveEndTime},</if>
|
|
<if test="leaveHour != null">leave_hour = #{leaveHour},</if>
|
|
<if test="remarks != null">remarks = #{remarks},</if>
|
|
<if test="createTime != null">create_time = #{createTime},</if>
|
|
<if test="createBy != null">create_by = #{createBy},</if>
|
|
<if test="updateTime != null">update_time = #{updateTime},</if>
|
|
<if test="updateBy != null">update_by = #{updateBy},</if>
|
|
<if test="leaveId != null">leave_id = #{leaveId},</if>
|
|
<if test="delFlag != null">del_flag = #{delFlag},</if>
|
|
</trim>
|
|
where id = #{id}
|
|
</update>
|
|
<!-- 根据请假主键查询请假详情 -->
|
|
<select id="selectRzLeaveDetailByLeaveId" parameterType="Long" resultMap="RzLeaveDetailResult">
|
|
<include refid="selectRzLeaveDetailVo"/>
|
|
where del_flag = '0' and leave_id = #{leaveId}
|
|
</select>
|
|
<!-- 根据姓名,部门查询请假情况 -->
|
|
<select id="selectRzLeaveDetailByName" resultMap="RzLeaveDetailResult">
|
|
select d.*
|
|
from rz_leave l,rz_leave_detail d
|
|
where l.id = d.leave_id and l.dept_id = #{deptId} and l.name = #{name} and DATE_FORMAT( l.leave_date, '%Y%m' ) = DATE_FORMAT(Now() , '%Y%m' ) and l.del_flag = '0'
|
|
</select>
|
|
|
|
<select id="selectRzLeaveDetailByUserIdAndDate" resultMap="RzLeaveDetailResult">
|
|
select d.*
|
|
from rz_leave_detail d left join rz_leave l on d.leave_id = l.id
|
|
where l.user_id = #{userId}
|
|
and l.del_flag = '0'
|
|
and DATE_FORMAT( d.leave_start_time, '%Y%m%d' ) <= DATE_FORMAT(#{date} , '%Y%m%d' )
|
|
and DATE_FORMAT( d.leave_end_time, '%Y%m%d' ) >= DATE_FORMAT(#{date} , '%Y%m%d' )
|
|
|
|
</select>
|
|
|
|
<select id="getLeaveHour" resultType="java.util.Map">
|
|
SELECT l.user_id as staffId, sum(JSON_EXTRACT(ld.extension,CONCAT('$.',CONCAT("hours",DATE_FORMAT(#{date},'%m'))))) as leaveHour
|
|
FROM `rz_leave_detail` ld left join rz_leave l on l.id = ld.leave_id
|
|
where JSON_EXTRACT(extension,CONCAT('$.',CONCAT("month",DATE_FORMAT(#{date},'%m'))))=DATE_FORMAT(#{date},'%Y-%m')
|
|
GROUP BY l.user_id
|
|
</select>
|
|
|
|
<select id="selectLeaveHourByUserIdAndDateAndType" resultType="java.lang.Long">
|
|
SELECT ifnull(sum(JSON_EXTRACT(ld.extension,CONCAT('$.',CONCAT("hours",DATE_FORMAT(#{date},'%m'))))), 0)
|
|
FROM `rz_leave_detail` ld left join rz_leave l on l.id = ld.leave_id
|
|
where ld.del_flag = '0' and ld.type = #{type} and l.user_id=#{userId} and JSON_EXTRACT(extension,CONCAT('$.',CONCAT("month",DATE_FORMAT(#{date},'%m'))))=DATE_FORMAT(#{date},'%Y-%m')
|
|
</select>
|
|
|
|
|
|
|
|
|
|
</mapper>
|