103 lines
5.3 KiB
XML
103 lines
5.3 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.attendance.mapper.RzAttendanceDetailMapper">
|
|
|
|
<resultMap type="RzAttendanceDetail" id="RzAttendanceDetailResult">
|
|
<result property="id" column="id" />
|
|
<result property="staffId" column="staff_id" />
|
|
<result property="name" column="name" />
|
|
<result property="equipmentCode" column="equipment_code" />
|
|
<result property="buttonType" column="button_type" />
|
|
<result property="dateTime" column="date_time" />
|
|
<result property="remark" column="remark" />
|
|
<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="selectRzAttendanceDetailVo">
|
|
select id, staff_id, name, equipment_code, button_type, date_time, remark, del_flag, create_by, create_time, update_by, update_time from rz_attendance_detail
|
|
</sql>
|
|
|
|
<select id="selectLastRzAttendanceDetail" resultMap="RzAttendanceDetailResult">
|
|
<include refid="selectRzAttendanceDetailVo"/>
|
|
where del_flag = '0' and staff_id = #{staffId} order by date_time desc limit 1
|
|
</select>
|
|
|
|
<insert id="insertRzAttendanceDetail" parameterType="RzAttendanceDetail" useGeneratedKeys="true" keyProperty="id">
|
|
insert into rz_attendance_detail
|
|
<trim prefix="(" suffix=")" suffixOverrides=",">
|
|
<if test="staffId != null">staff_id,</if>
|
|
<if test="name != null">name,</if>
|
|
<if test="equipmentCode != null">equipment_code,</if>
|
|
<if test="buttonType != null">button_type,</if>
|
|
<if test="dateTime != null">date_time,</if>
|
|
<if test="remark != null">remark,</if>
|
|
<if test="delFlag != null">del_flag,</if>
|
|
<if test="createBy != null">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="staffId != null">#{staffId},</if>
|
|
<if test="name != null">#{name},</if>
|
|
<if test="equipmentCode != null">#{equipmentCode},</if>
|
|
<if test="buttonType != null">#{buttonType},</if>
|
|
<if test="dateTime != null">#{dateTime},</if>
|
|
<if test="remark != null">#{remark},</if>
|
|
<if test="delFlag != null">#{delFlag},</if>
|
|
<if test="createBy != null">#{createBy},</if>
|
|
<if test="createTime != null">#{createTime},</if>
|
|
<if test="updateBy != null">#{updateBy},</if>
|
|
<if test="updateTime != null">#{updateTime},</if>
|
|
</trim>
|
|
</insert>
|
|
|
|
<update id="updateRzAttendanceDetail" parameterType="RzAttendanceDetail">
|
|
update rz_attendance_detail
|
|
<trim prefix="SET" suffixOverrides=",">
|
|
<if test="staffId != null">staff_id = #{staffId},</if>
|
|
<if test="name != null">name = #{name},</if>
|
|
<if test="equipmentCode != null">equipment_code = #{equipmentCode},</if>
|
|
<if test="buttonType != null">button_type = #{buttonType},</if>
|
|
<if test="dateTime != null">date_time = #{dateTime},</if>
|
|
<if test="remark != null">remark = #{remark},</if>
|
|
<if test="delFlag != null">del_flag = #{delFlag},</if>
|
|
<if test="createBy != null">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>
|
|
<!-- 最后一次上班卡 or 加班卡,计算工时 非下班卡-->
|
|
<select id="selectRzAttendanceDetailByStaffId" resultMap="RzAttendanceDetailResult">
|
|
<include refid="selectRzAttendanceDetailVo"/>
|
|
where del_flag = '0' and staff_id = #{staffId} and button_type != '下班卡' order by date_time desc limit 1
|
|
</select>
|
|
<!-- 最后一次上班卡 指定-->
|
|
<select id="selectLastWorkCardByStaffId" resultMap="RzAttendanceDetailResult">
|
|
<include refid="selectRzAttendanceDetailVo"/>
|
|
where del_flag = '0' and staff_id = #{staffId} and button_type like '上班卡%' order by date_time desc limit 1
|
|
</select>
|
|
<!-- 查询指定月份的打卡信息-->
|
|
<select id="selectRzAttendanceDetailByMonth" resultMap="RzAttendanceDetailResult">
|
|
<include refid="selectRzAttendanceDetailVo"/>
|
|
where del_flag = '0' and DATE_FORMAT( date_time, '%Y%m' ) = DATE_FORMAT(#{date} , '%Y%m' )
|
|
order by create_time
|
|
</select>
|
|
|
|
<select id="checkOverTimeCard" resultType="java.lang.Long">
|
|
select count(id) from rz_attendance_detail
|
|
where del_flag = '0' and DATE_FORMAT( date_time, '%Y%m%d' ) = DATE_FORMAT(#{date} , '%Y%m%d' ) and staff_id = #{userId} and button_type = '加班卡'
|
|
</select>
|
|
|
|
|
|
|
|
</mapper>
|