Blame view

backend/bpm-runtime/src/main/resources/mapper/BpmTaskSignLineMapper.xml 2.72 KB
8ea9c133   陈威   初始化提交
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
<?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.hotent.runtime.dao.BpmTaskSignLineDao">
	<resultMap id="BpmTaskSignLine" type="com.hotent.runtime.model.BpmTaskSignLine">
		<id property="id" column="ID_" jdbcType="VARCHAR"/>
		<result property="instanceId" column="INSTANCE_ID_" jdbcType="VARCHAR"/>
		<result property="nodeId" column="NODE_ID_" jdbcType="VARCHAR"/>
		<result property="taskId" column="TASK_ID_" jdbcType="VARCHAR"/>
		<result property="parentTaskId" column="PARENT_TASK_ID_" jdbcType="VARCHAR"/>
		<result property="path" column="PATH_" jdbcType="VARCHAR"/>
		<result property="status" column="STATUS_" jdbcType="VARCHAR"/>
		<result property="executor" column="EXECUTOR_" jdbcType="VARCHAR"/>
		<result property="action" column="ACTION_" jdbcType="VARCHAR"/>
		<result property="isRead" column="IS_READ_" jdbcType="NUMERIC"/>
	</resultMap>
	
	<select id="getByTaskId"   parameterType="java.lang.String" resultMap="BpmTaskSignLine">
		SELECT * FROM bpm_task_sign_line 
		WHERE 
		TASK_ID_=#{id}
	</select>
	
	<select id="getByInstNodeIdAndStatus"   parameterType="java.lang.String" resultMap="BpmTaskSignLine">
		SELECT line.*,
		(select IS_READ_ from bpm_check_opinion opinion where  opinion.TASK_ID_=line.TASK_ID_ and opinion.STATUS_ = 'awaiting_check' ) IS_READ_
		 FROM bpm_task_sign_line line
		<where>
			line.NODE_ID_=#{nodeId} and line.INSTANCE_ID_=#{instanceId} and line.PATH_ like  '${rootTaskId}%'
			<if test="status!=null">and line.STATUS_ = #{status}</if>
		</where>
	</select>
	<select id="getByPathChildAndStatus"   parameterType="java.lang.String" resultMap="BpmTaskSignLine">
		SELECT line.*,
		(select IS_READ_ from bpm_check_opinion opinion where  opinion.TASK_ID_=line.TASK_ID_ and opinion.STATUS_ = 'awaiting_check' ) IS_READ_
		 FROM bpm_task_sign_line line
		<where>
			line.PATH_ LIKE '${path}%'
			<if test="status!=null">and line.STATUS_ = #{status}</if>
		</where>
	</select>
	
	<update id="updateStatusByTaskIds" parameterType="com.hotent.runtime.model.BpmTaskSignLine">
		UPDATE bpm_task_sign_line SET
		STATUS_=#{status,jdbcType=VARCHAR}
		WHERE
		TASK_ID_ in
	    <foreach collection="taskIds" index="index" item="item" open="(" separator="," close=")">
	        #{item}
	    </foreach>
	</update>
	
	<delete id="removeByTaskId" parameterType="java.lang.String">
		DELETE FROM bpm_task_sign_line 
		WHERE
		TASK_ID_=#{taskId}
	</delete>
	<delete id="removeByInstIdNodeId" parameterType="java.lang.String">
		DELETE FROM bpm_task_sign_line 
		<where>
			INSTANCE_ID_=#{instanceId} and PATH_ like  '${rootTaskId}%'
			<if test="nodeId !=null ">
				  and NODE_ID_ = #{nodeId}
			</if>
		</where>
	</delete>
	
</mapper>