| <?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.zy.asrs.mapper.WrkMastMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.zy.asrs.entity.WrkMast"> | 
|         <id column="wrk_no" property="wrkNo" /> | 
|         <result column="inv_wh" property="invWh" /> | 
|         <result column="ymd" property="ymd" /> | 
|         <result column="mk" property="mk" /> | 
|         <result column="whs_type" property="whsType" /> | 
|         <result column="wrk_sts" property="wrkSts" /> | 
|         <result column="io_type" property="ioType" /> | 
|         <result column="crn_no" property="crnNo" /> | 
|         <result column="ste_no" property="steNo" /> | 
|         <result column="out_most" property="outMost" /> | 
|         <result column="sheet_no" property="sheetNo" /> | 
|         <result column="io_pri" property="ioPri" /> | 
|         <result column="wrk_date" property="wrkDate" /> | 
|         <result column="loc_no" property="locNo" /> | 
|         <result column="sta_no" property="staNo" /> | 
|         <result column="source_sta_no" property="sourceStaNo" /> | 
|         <result column="source_loc_no" property="sourceLocNo" /> | 
|         <result column="loc_sts" property="locSts" /> | 
|         <result column="picking" property="picking" /> | 
|         <result column="link_mis" property="linkMis" /> | 
|         <result column="online_yn" property="onlineYn" /> | 
|         <result column="upd_mk" property="updMk" /> | 
|         <result column="exit_mk" property="exitMk" /> | 
|         <result column="plt_type" property="pltType" /> | 
|         <result column="empty_mk" property="emptyMk" /> | 
|         <result column="io_time" property="ioTime" /> | 
|         <result column="ctn_type" property="ctnType" /> | 
|         <result column="packed" property="packed" /> | 
|         <result column="ove_mk" property="oveMk" /> | 
|         <result column="mtn_type" property="mtnType" /> | 
|         <result column="user_no" property="userNo" /> | 
|         <result column="crn_str_time" property="crnStrTime" /> | 
|         <result column="crn_end_time" property="crnEndTime" /> | 
|         <result column="plc_str_time" property="plcStrTime" /> | 
|         <result column="crn_pos_time" property="crnPosTime" /> | 
|         <result column="load_time" property="loadTime" /> | 
|         <result column="exp_time" property="expTime" /> | 
|         <result column="ref_wrkno" property="refWrkno" /> | 
|         <result column="ref_iotime" property="refIotime" /> | 
|         <result column="modi_user" property="modiUser" /> | 
|         <result column="modi_time" property="modiTime" /> | 
|         <result column="appe_user" property="appeUser" /> | 
|         <result column="appe_time" property="appeTime" /> | 
|         <result column="pause_mk" property="pauseMk" /> | 
|         <result column="error_time" property="errorTime" /> | 
|         <result column="error_memo" property="errorMemo" /> | 
|         <result column="ctn_kind" property="ctnKind" /> | 
|         <result column="manu_type" property="manuType" /> | 
|         <result column="memo" property="memo" /> | 
|         <result column="sc_weight" property="scWeight" /> | 
|         <result column="log_mk" property="logMk" /> | 
|         <result column="log_err_time" property="logErrTime" /> | 
|         <result column="log_err_memo" property="logErrMemo" /> | 
|         <result column="barcode" property="barcode" /> | 
|         <result column="ctn_no" property="ctnNo" /> | 
|         <result column="full_plt" property="fullPlt" /> | 
|   | 
|     </resultMap> | 
|   | 
|     <select id="selectByLocNo"  resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where source_loc_no = #{sourceLocNo} | 
|     </select> | 
|   | 
|     <select id="selectByLocNo1"  resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where source_loc_no = #{sourceLocNo} or loc_no=#{sourceLocNo} | 
|     </select> | 
|   | 
|     <select id="selectToBeCompleteData" resultMap="BaseResultMap"> | 
|         select * from asr_wrk_mast where ((wrk_sts = 4 Or wrk_sts = 14 ) and io_type != 103 and io_type != 104 and io_type != 107 ) or (wrk_sts = 2 and io_type=6) order by upd_mk,io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectToBeHistoryData" resultMap="BaseResultMap"> | 
|         select * from asr_wrk_mast | 
|         where wrk_sts=5 | 
|         or (wrk_sts=15 and ove_mk='Y' and wrk_no not in (select wrk_no from asr_bas_devp)) | 
|         or (wrk_sts=15 and dateadd(mi,15,crn_end_time) <= getdate() and wrk_no not in (select wrk_no from asr_bas_devp)) | 
|         or (wrk_sts=15 and crn_end_time is null and wrk_no not in (select wrk_no from asr_bas_devp)) | 
|         order by io_time,wrk_no asc | 
|     </select> | 
|   | 
|     <select id="selectPakInStep1" resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where source_sta_no=#{sourceStaNo} and wrk_sts=2 and barcode=#{barcode} and (io_type=1 or io_type=10) order by io_pri desc,io_time,wrk_no ASC | 
|     </select> | 
|   | 
|     <select id="selectPakInStep11" resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where source_sta_no=#{sourceStaNo} and wrk_sts=1 and (io_type=1 or io_type=10) order by io_pri desc,io_time,wrk_no ASC | 
|     </select> | 
|   | 
|     <select id="selectPakInStep23456" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts in (2,3,4,5,6,7,8) and crn_no=#{crnNo} and wrk_no=#{workNo} and sta_no=#{staNo} and (io_type=1 or io_type=10 or io_type=53 or io_type=54 or io_type=57) order by io_pri desc,io_time,wrk_no ASC | 
|     </select> | 
|   | 
|     <select id="selectPakInStep45" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_no=#{workNo} and wrk_sts in (4,5) | 
|     </select> | 
|   | 
|     <select id="selectCrnWaiting" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_no=#{workNo} and wrk_sts in (4,5,7,13, 16) | 
|     </select> | 
|   | 
|     <select id="selectCarWaiting" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_no=#{workNo} and wrk_sts in (2,8,11,14) | 
|     </select> | 
|   | 
|     <select id="selectPickStep" resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where wrk_no=#{wrkNo} and wrk_sts=17 and (io_type=103 or io_type=107 or io_type=104) | 
|     </select> | 
|   | 
|     <select id="selectPickStepByBarcode" resultMap="BaseResultMap"> | 
|         select top 1 * from asr_wrk_mast where barcode=#{barcode} and wrk_sts=17 and (io_type=103 or io_type=107 or io_type=104) | 
|     </select> | 
|   | 
|     <select id="selectPakOutStep111215" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where crn_no=#{crnNo} and source_sta_no=#{sourceStaNo} and wrk_sts in (11,12,13,14,15, 16) and io_type>100 order by io_pri desc,io_time,wrk_no asc | 
|     </select> | 
|   | 
|     <select id="selectPakOutStep16" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where source_sta_no=#{sourceStaNo} and wrk_sts=16 and io_type > 100 order by io_pri desc,io_time desc,wrk_no ASC | 
|     </select> | 
|   | 
|     <select id="selectLocMove" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts in (3,6,11,12,15) and io_type=11 and crn_no=#{crnNo} order by io_pri desc,io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectLocMove111" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts in (3,6,11,12,15) and io_type=111 and crn_no=#{crnNo} order by io_pri desc,io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectLocMoving" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts=12 and io_type=11 and crn_no=#{crnNo} order by io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectWorking" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where 1=1 and (wrk_sts=7 or wrk_sts=16) and crn_no=#{crnNo} order by io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectWorking1" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast | 
|         where 1=1 and wrk_no!=#{wrkNo} and ((wrk_sts>11 and wrk_sts < 17) or (wrk_sts=11 and ste_no is not null and ste_no>0)) and crn_no=#{crnNo} | 
|         order by io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectPakin" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast | 
|         where 1=1 | 
|         and wrk_sts in (3,4,5,6,7,8,9) | 
|         and crn_no=#{crnNo} | 
|         <if test="steNo != null"> | 
|             and ste_no = #{steNo} | 
|         </if> | 
|     </select> | 
|   | 
|     <select id="selectPakout" resultMap="BaseResultMap"> | 
|         select top 1 * | 
|         from dbo.asr_wrk_mast | 
|         where 1=1 | 
|         and | 
|         ( | 
|             (wrk_sts in (12,13,14,15,16,17) and io_type in (101, 110)) | 
|             or | 
|             (wrk_sts in (12,13,14,15,16) and io_type in (103, 104, 107)) | 
|         ) | 
|         and crn_no=#{crnNo} | 
|         <if test="steNo != null"> | 
|             and ste_no = #{steNo} | 
|         </if> | 
|     </select> | 
|   | 
|     <select id="selectLocMoveWorking" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where crn_no=#{crnNo} and wrk_sts != 17 and io_type=11 order by io_pri desc,io_time,wrk_no asc | 
|     </select> | 
|   | 
|     <select id="selectLocMove17" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts in (2,3,6,17) and io_type=11 and crn_no=#{crnNo} order by io_pri desc,io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectPick17" resultMap="BaseResultMap"> | 
|         select * from dbo.asr_wrk_mast | 
|         where 1=1 and (io_type=103 or io_type=107 or io_type=104) and wrk_sts = 17 | 
|         <if test="staNo != null"> | 
|             and sta_no = #{staNo} | 
|         </if> | 
|         <if test="wrkNo != null"> | 
|             and wrk_no = #{wrkNo} | 
|         </if> | 
|     </select> | 
|   | 
|     <select id="selectLocMoveData" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where crn_no=#{crnNo} and io_type=11 order by io_pri desc,io_time,wrk_no asc | 
|     </select> | 
|   | 
|     <select id="selectSteNoData" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where ste_no=#{steNo} and wrk_sts!=17 and wrk_sts!=18 order by io_pri desc,io_time,wrk_no asc | 
|     </select> | 
|   | 
|     <select id="selectWrkStsAndIoType" resultMap="BaseResultMap"> | 
|         select * from dbo.asr_wrk_mast where 1=1 and wrk_sts>11 and (io_type=103 or io_type=107) and crn_no=2 and io_type!=11 | 
|         <if test="sour > 200"> | 
|             and source_sta_no > 200 | 
|         </if> | 
|         <if test="sour < 200"> | 
|             and source_sta_no < 200 | 
|         </if> | 
|   | 
|     </select> | 
|     <select id="selectWrkStsAndIoType0" resultMap="BaseResultMap"> | 
|         select * from dbo.asr_wrk_mast where 1=1 and wrk_sts>11 and io_type!=11 | 
|         and (io_type=103 or io_type=107) | 
|         <if test="sour > 200"> | 
|             and source_sta_no > 200 | 
|         </if> | 
|         <if test="sour < 200"> | 
|             and source_sta_no < 200 | 
|         </if> | 
|   | 
|     </select> | 
|   | 
|     <select id="selectWrkStsAndIoType107Count" resultType="java.lang.Integer"> | 
|         select count (*) from dbo.asr_wrk_mast where 1=1 | 
|         and wrk_no!=#{workNo} | 
|         and | 
|         ( | 
|         <choose> | 
|             <when test="sour < 200"> | 
|                 (wrk_sts > 11 and wrk_sts < 18 and source_sta_no < 200 and io_type > 101 and io_type < 110) | 
|                 or | 
|                 (wrk_sts = 11 and source_sta_no < 200 and io_type > 101 and io_type < 110 and ste_no is not null) | 
|                 or | 
|                 (wrk_sts < 3 and sta_no < 200 and io_type < 100 and io_type > 9 and io_type != 11 ) | 
|             </when> | 
|             <otherwise> | 
|                 (wrk_sts > 11 and wrk_sts < 18 and source_sta_no > 200 and io_type > 101 and io_type < 110) | 
|                 or | 
|                 (wrk_sts = 11 and source_sta_no > 200 and io_type > 101 and io_type < 110 and ste_no is not null) | 
|                 or | 
|                 (wrk_sts < 3 and sta_no > 200 and io_type < 100 and io_type > 9 and io_type != 11) | 
|             </otherwise> | 
|         </choose> | 
|         ) | 
|   | 
|     </select> | 
|   | 
|     <select id="selectWrkStsAndIoType1" resultMap="BaseResultMap"> | 
|         select * from dbo.asr_wrk_mast where 1=1 and wrk_sts>11 and io_type=101 | 
|         <if test="sour > 200"> | 
|             and source_sta_no > 200 | 
|         </if> | 
|         <if test="sour < 200"> | 
|             and source_sta_no < 200 | 
|         </if> | 
|   | 
|     </select> | 
|   | 
|     <!--                                       入出库模式相关                                      --> | 
|     <select id="selectWorkingPakin" resultMap="BaseResultMap"> | 
|         select top 1 * from dbo.asr_wrk_mast where wrk_sts in (2,3,4) and io_type != 11 and source_sta_no = #{sourceStaNo} order by io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectWorkingPakout" resultMap="BaseResultMap"> | 
|         select top 1 * | 
|         from dbo.asr_wrk_mast | 
|         where wrk_sts > 10 | 
|         and io_type > 100 and io_type != 11 | 
|         and source_sta_no = #{sourceStaNo} | 
|         order by io_time,wrk_no | 
|     </select> | 
|   | 
|     <select id="selectShallowLoc" resultMap="BaseResultMap"> | 
|         select top 1 * | 
|         from dbo.asr_loc_mast | 
|         where 1=1 | 
|         and loc_sts!='F' and loc_sts!='D' and loc_sts != 'X' and loc_sts != 'O' | 
|         and bay1 = #{bay} | 
|         and lev1 = #{lev} | 
|         <if test="row <= 3"> | 
|             and row1 < #{row} | 
|         </if> | 
|         <if test="row > 3 and row <= 7"> | 
|             and row1 > #{row} | 
|             and row1 <= 7 | 
|         </if> | 
|         <if test="row > 7 and row <= 11"> | 
|             and row1 > 7 | 
|             and row1 < #{row} | 
|         </if> | 
|         <if test="row > 11 and row <= 14"> | 
|             and row1 > #{row} | 
|             and row1 <= 14 | 
|         </if> | 
|         <if test="row > 14 and row <= 18"> | 
|             and row1 > 14 | 
|             and row1 < #{row} | 
|         </if> | 
|         <if test="row > 18 and row <= 21"> | 
|             and row1 > #{row} | 
|             and row1 <= 21 | 
|         </if> | 
|     </select> | 
|   | 
| </mapper> |