ProRouteProcessMapper.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="com.ktg.mes.pro.mapper.ProRouteProcessMapper">
  6. <resultMap type="ProRouteProcess" id="ProRouteProcessResult">
  7. <result property="recordId" column="record_id" />
  8. <result property="routeId" column="route_id" />
  9. <result property="processId" column="process_id" />
  10. <result property="processCode" column="process_code" />
  11. <result property="processName" column="process_name" />
  12. <result property="orderNum" column="order_num" />
  13. <result property="nextProcessId" column="next_process_id" />
  14. <result property="nextProcessCode" column="next_process_code" />
  15. <result property="nextProcessName" column="next_process_name" />
  16. <result property="linkType" column="link_type" />
  17. <result property="defaultPreTime" column="default_pre_time" />
  18. <result property="defaultSufTime" column="default_suf_time" />
  19. <result property="colorCode" column="color_code" />
  20. <result property="keyFlag" column="key_flag" ></result>
  21. <result property="isCheck" column="is_check" ></result>
  22. <result property="remark" column="remark" />
  23. <result property="attr1" column="attr1" />
  24. <result property="attr2" column="attr2" />
  25. <result property="attr3" column="attr3" />
  26. <result property="attr4" column="attr4" />
  27. <result property="createBy" column="create_by" />
  28. <result property="createTime" column="create_time" />
  29. <result property="updateBy" column="update_by" />
  30. <result property="updateTime" column="update_time" />
  31. </resultMap>
  32. <sql id="selectProRouteProcessVo">
  33. select record_id, route_id, process_id, process_code, process_name, order_num, next_process_id, next_process_code, next_process_name, link_type, default_pre_time, default_suf_time, color_code,key_flag,is_check, remark, attr1, attr2, attr3, attr4, create_by, create_time, update_by, update_time from pro_route_process
  34. </sql>
  35. <select id="selectProRouteProcessList" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  36. <include refid="selectProRouteProcessVo"/>
  37. <where>
  38. <if test="routeId != null "> and route_id = #{routeId}</if>
  39. <if test="processId != null "> and process_id = #{processId}</if>
  40. <if test="processCode != null and processCode != ''"> and process_code = #{processCode}</if>
  41. <if test="processName != null and processName != ''"> and process_name like concat('%', #{processName}, '%')</if>
  42. <if test="orderNum != null "> and order_num = #{orderNum}</if>
  43. <if test="nextProcessId != null "> and next_process_id = #{nextProcessId}</if>
  44. <if test="nextProcessCode != null and nextProcessCode != ''"> and next_process_code = #{nextProcessCode}</if>
  45. <if test="nextProcessName != null and nextProcessName != ''"> and next_process_name like concat('%', #{nextProcessName}, '%')</if>
  46. <if test="linkType != null and linkType != ''"> and link_type = #{linkType}</if>
  47. <if test="defaultPreTime != null "> and default_pre_time = #{defaultPreTime}</if>
  48. <if test="defaultSufTime != null "> and default_suf_time = #{defaultSufTime}</if>
  49. <if test="colorCode != null and colorCode != ''"> and color_code = #{colorCode}</if>
  50. <if test="keyFlag !=null and keyFlag !=''"> and key_flag = #{keyFlag}</if>
  51. <if test="isCheck !=null and isCheck !=''"> and is_check = #{isCheck}</if>
  52. </where>
  53. order by order_num asc
  54. </select>
  55. <select id="selectProRouteProcessByRecordId" parameterType="Long" resultMap="ProRouteProcessResult">
  56. <include refid="selectProRouteProcessVo"/>
  57. where record_id = #{recordId}
  58. </select>
  59. <select id="checkOrderNumExists" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  60. <include refid="selectProRouteProcessVo"/>
  61. where route_id = #{routeId} and order_num = #{orderNum} offset 0 rows fetch next 1 rows only
  62. </select>
  63. <select id="checkProcessExists" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  64. <include refid="selectProRouteProcessVo"/>
  65. where route_id = #{routeId} and process_id = #{processId} offset 0 rows fetch next 1 rows only
  66. </select>
  67. <select id="checkUpdateFlagUnique" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  68. <include refid="selectProRouteProcessVo"/>
  69. where route_id = #{routeId} and key_flag = 'Y' offset 0 rows fetch next 1 rows only
  70. </select>
  71. <select id="findPreProcess" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  72. <include refid="selectProRouteProcessVo"/>
  73. where route_id = #{routeId}
  74. <choose>
  75. <when test="orderNum != null "> and order_num &lt; #{orderNum}</when>
  76. <otherwise>
  77. AND order_num &lt; (
  78. SELECT order_num
  79. FROM pro_route_process
  80. WHERE route_id = #{routeId} offset 0 rows fetch next 1 rows only
  81. )
  82. </otherwise>
  83. </choose>
  84. ORDER BY order_num DESC offset 0 rows fetch next 1 rows only
  85. </select>
  86. <select id="findNextProcess" parameterType="ProRouteProcess" resultMap="ProRouteProcessResult">
  87. <include refid="selectProRouteProcessVo"/>
  88. where route_id = #{routeId}
  89. <choose>
  90. <when test="orderNum != null "> and order_num &gt; #{orderNum}</when>
  91. <otherwise>
  92. AND order_num &gt; (
  93. SELECT order_num
  94. FROM pro_route_process
  95. WHERE route_id = #{routeId} offset 0 rows fetch next 1 rows only
  96. )
  97. </otherwise>
  98. </choose>
  99. ORDER BY order_num ASC offset 0 rows fetch next 1 rows only
  100. </select>
  101. <insert id="insertProRouteProcess" parameterType="ProRouteProcess" useGeneratedKeys="true" keyProperty="recordId">
  102. insert into pro_route_process
  103. <trim prefix="(" suffix=")" suffixOverrides=",">
  104. <if test="routeId != null">route_id,</if>
  105. <if test="processId != null">process_id,</if>
  106. <if test="processCode != null">process_code,</if>
  107. <if test="processName != null">process_name,</if>
  108. <if test="orderNum != null">order_num,</if>
  109. <if test="nextProcessId != null">next_process_id,</if>
  110. <if test="nextProcessCode != null">next_process_code,</if>
  111. <if test="nextProcessName != null">next_process_name,</if>
  112. <if test="linkType != null">link_type,</if>
  113. <if test="defaultPreTime != null">default_pre_time,</if>
  114. <if test="defaultSufTime != null">default_suf_time,</if>
  115. <if test="colorCode != null">color_code,</if>
  116. <if test="keyFlag !=null">key_flag,</if>
  117. <if test="isCheck !=null">is_check,</if>
  118. <if test="remark != null">remark,</if>
  119. <if test="attr1 != null">attr1,</if>
  120. <if test="attr2 != null">attr2,</if>
  121. <if test="attr3 != null">attr3,</if>
  122. <if test="attr4 != null">attr4,</if>
  123. <if test="createBy != null">create_by,</if>
  124. <if test="createTime != null">create_time,</if>
  125. <if test="updateBy != null">update_by,</if>
  126. <if test="updateTime != null">update_time,</if>
  127. </trim>
  128. <trim prefix="values (" suffix=")" suffixOverrides=",">
  129. <if test="routeId != null">#{routeId},</if>
  130. <if test="processId != null">#{processId},</if>
  131. <if test="processCode != null">#{processCode},</if>
  132. <if test="processName != null">#{processName},</if>
  133. <if test="orderNum != null">#{orderNum},</if>
  134. <if test="nextProcessId != null">#{nextProcessId},</if>
  135. <if test="nextProcessCode != null">#{nextProcessCode},</if>
  136. <if test="nextProcessName != null">#{nextProcessName},</if>
  137. <if test="linkType != null">#{linkType},</if>
  138. <if test="defaultPreTime != null">#{defaultPreTime},</if>
  139. <if test="defaultSufTime != null">#{defaultSufTime},</if>
  140. <if test="colorCode != null">#{colorCode},</if>
  141. <if test="keyFlag !=null">#{keyFlag},</if>
  142. <if test="isCheck !=null">#{isCheck},</if>
  143. <if test="remark != null">#{remark},</if>
  144. <if test="attr1 != null">#{attr1},</if>
  145. <if test="attr2 != null">#{attr2},</if>
  146. <if test="attr3 != null">#{attr3},</if>
  147. <if test="attr4 != null">#{attr4},</if>
  148. <if test="createBy != null">#{createBy},</if>
  149. <if test="createTime != null">#{createTime},</if>
  150. <if test="updateBy != null">#{updateBy},</if>
  151. <if test="updateTime != null">#{updateTime},</if>
  152. </trim>
  153. </insert>
  154. <update id="updateProRouteProcess" parameterType="ProRouteProcess">
  155. update pro_route_process
  156. <trim prefix="SET" suffixOverrides=",">
  157. <if test="routeId != null">route_id = #{routeId},</if>
  158. <if test="processId != null">process_id = #{processId},</if>
  159. <if test="processCode != null">process_code = #{processCode},</if>
  160. <if test="processName != null">process_name = #{processName},</if>
  161. <if test="orderNum != null">order_num = #{orderNum},</if>
  162. <if test="nextProcessId != null">next_process_id = #{nextProcessId},</if>
  163. <if test="nextProcessCode != null">next_process_code = #{nextProcessCode},</if>
  164. <if test="nextProcessName != null">next_process_name = #{nextProcessName},</if>
  165. <if test="linkType != null">link_type = #{linkType},</if>
  166. <if test="defaultPreTime != null">default_pre_time = #{defaultPreTime},</if>
  167. <if test="defaultSufTime != null">default_suf_time = #{defaultSufTime},</if>
  168. <if test="keyFlag !=null">key_flag = #{keyFlag},</if>
  169. <if test="isCheck !=null">is_check = #{isCheck},</if>
  170. <if test="colorCode != null">color_code = #{colorCode},</if>
  171. <if test="remark != null">remark = #{remark},</if>
  172. <if test="attr1 != null">attr1 = #{attr1},</if>
  173. <if test="attr2 != null">attr2 = #{attr2},</if>
  174. <if test="attr3 != null">attr3 = #{attr3},</if>
  175. <if test="attr4 != null">attr4 = #{attr4},</if>
  176. <if test="createBy != null">create_by = #{createBy},</if>
  177. <if test="createTime != null">create_time = #{createTime},</if>
  178. <if test="updateBy != null">update_by = #{updateBy},</if>
  179. <if test="updateTime != null">update_time = #{updateTime},</if>
  180. </trim>
  181. where record_id = #{recordId}
  182. </update>
  183. <delete id="deleteProRouteProcessByRecordId" parameterType="Long">
  184. delete from pro_route_process where record_id = #{recordId}
  185. </delete>
  186. <delete id="deleteProRouteProcessByRecordIds" parameterType="String">
  187. delete from pro_route_process where record_id in
  188. <foreach item="recordId" collection="array" open="(" separator="," close=")">
  189. #{recordId}
  190. </foreach>
  191. </delete>
  192. <delete id="deleteByRouteId" parameterType="Long">
  193. delete from pro_route_process where route_id = #{routeId}
  194. </delete>
  195. </mapper>