evo-Financial-pc/evo-admin/target/classes/mapper/personnelMatters/RzLeaveMapper.xml
2025-05-04 11:02:42 +08:00

130 lines
7.2 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.RzLeaveMapper">
<resultMap type="RzLeave" id="RzLeaveResult">
<result property="id" column="id" />
<result property="userId" column="user_id" />
<result property="deptId" column="dept_id" />
<result property="name" column="name" />
<result property="leaveDate" column="leave_date" />
<result property="sickHours" column="sick_hours" />
<result property="absenceHours" column="absence_hours" />
<result property="compensatoryHours" column="compensatory_hours" />
<result property="marriageHours" column="marriage_hours" />
<result property="annualHours" column="annual_hours" />
<result property="maternityHours" column="maternity_hours" />
<result property="paternityHours" column="paternity_hours" />
<result property="funeralHours" column="funeral_hours" />
<result property="workHours" column="work_hours" />
<result property="delFlag" column="del_flag" />
<result property="createBy" column="create_by" />
<result property="createTime" column="create_time" />
<result property="updateBy" column="update_by" />
<result property="updateTime" column="update_time" />
</resultMap>
<sql id="selectRzLeaveVo">
select id, user_id, dept_id, name, leave_date, sick_hours, absence_hours, compensatory_hours, marriage_hours, annual_hours, maternity_hours, paternity_hours, funeral_hours, work_hours, del_flag, create_by, create_time, update_by, update_time from rz_leave d
</sql>
<select id="selectRzLeaveList" parameterType="RzLeave" resultMap="RzLeaveResult">
<include refid="selectRzLeaveVo"/>
<where>
d.del_flag = '0'
<if test="name != null and name != ''"> and name like concat('%',#{name},'%')</if>
<if test="userId != null"> and user_id = #{userId}</if>
<if test="deptId != null "> and d.dept_id = #{deptId}</if>
<choose>
<when test="leaveDate != null">and DATE_FORMAT( d.leave_date, '%Y%m' ) = DATE_FORMAT( #{leaveDate} , '%Y%m' )</when>
<otherwise>
and DATE_FORMAT( d.leave_date, '%Y%m' ) = DATE_FORMAT(NOW() , '%Y%m' )
</otherwise>
</choose>
${params.dataScope}
</where>
</select>
<select id="selectRzLeaveById" parameterType="Long" resultMap="RzLeaveResult">
<include refid="selectRzLeaveVo"/>
where id = #{id}
</select>
<insert id="insertRzLeave" parameterType="RzLeave" useGeneratedKeys="true" keyProperty="id">
insert into rz_leave
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="userId != null">user_id,</if>
<if test="deptId != null">dept_id,</if>
<if test="name != null and name != ''">name,</if>
<if test="leaveDate != null">leave_date,</if>
<if test="sickHours != null">sick_hours,</if>
<if test="absenceHours != null">absence_hours,</if>
<if test="compensatoryHours != null">compensatory_hours,</if>
<if test="marriageHours != null">marriage_hours,</if>
<if test="annualHours != null">annual_hours,</if>
<if test="maternityHours != null">maternity_hours,</if>
<if test="paternityHours != null">paternity_hours,</if>
<if test="funeralHours != null">funeral_hours,</if>
<if test="workHours != null">work_hours,</if>
<if test="delFlag != null and delFlag != ''">del_flag,</if>
<if test="createBy != null and createBy != ''">create_by,</if>
<if test="createTime != null">create_time,</if>
<if test="updateBy != null">update_by,</if>
<if test="updateTime != null">update_time,</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="userId != null">#{userId},</if>
<if test="deptId != null">#{deptId},</if>
<if test="name != null and name != ''">#{name},</if>
<if test="leaveDate != null">#{leaveDate},</if>
<if test="sickHours != null">#{sickHours},</if>
<if test="absenceHours != null">#{absenceHours},</if>
<if test="compensatoryHours != null">#{compensatoryHours},</if>
<if test="marriageHours != null">#{marriageHours},</if>
<if test="annualHours != null">#{annualHours},</if>
<if test="maternityHours != null">#{maternityHours},</if>
<if test="paternityHours != null">#{paternityHours},</if>
<if test="funeralHours != null">#{funeralHours},</if>
<if test="workHours != null">#{workHours},</if>
<if test="delFlag != null and delFlag != ''">#{delFlag},</if>
<if test="createBy != null and createBy != ''">#{createBy},</if>
<if test="createTime != null">#{createTime},</if>
<if test="updateBy != null">#{updateBy},</if>
<if test="updateTime != null">#{updateTime},</if>
</trim>
</insert>
<update id="updateRzLeave" parameterType="RzLeave">
update rz_leave
<trim prefix="SET" suffixOverrides=",">
<if test="userId != null">user_id = #{userId},</if>
<if test="deptId != null">dept_id = #{deptId},</if>
<if test="name != null and name != ''">name = #{name},</if>
<if test="leaveDate != null">leave_date = #{leaveDate},</if>
<if test="sickHours != null">sick_hours = #{sickHours},</if>
<if test="absenceHours != null">absence_hours = #{absenceHours},</if>
<if test="compensatoryHours != null">compensatory_hours = #{compensatoryHours},</if>
<if test="marriageHours != null">marriage_hours = #{marriageHours},</if>
<if test="annualHours != null">annual_hours = #{annualHours},</if>
<if test="maternityHours != null">maternity_hours = #{maternityHours},</if>
<if test="paternityHours != null">paternity_hours = #{paternityHours},</if>
<if test="funeralHours != null">funeral_hours = #{funeralHours},</if>
<if test="workHours != null">work_hours = #{workHours},</if>
<if test="delFlag != null and delFlag != ''">del_flag = #{delFlag},</if>
<if test="createBy != null and createBy != ''">create_by = #{createBy},</if>
<if test="createTime != null">create_time = #{createTime},</if>
<if test="updateBy != null">update_by = #{updateBy},</if>
<if test="updateTime != null">update_time = #{updateTime},</if>
</trim>
where id = #{id}
</update>
<!-- 根据员工ID查询请假统计 -->
<select id="queryRzLeaveByDateAndUserId" resultMap="RzLeaveResult">
<include refid="selectRzLeaveVo"/>
where del_flag = '0' and DATE_FORMAT( leave_date, '%Y%m' ) = DATE_FORMAT( #{date} , '%Y%m' ) and user_id = #{userId}
</select>
</mapper>