| <?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.LocMastMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="com.zy.asrs.entity.LocMast"> | 
|         <id column="loc_no" property="locNo" /> | 
|         <result column="whs_type" property="whsType" /> | 
|         <result column="plt_type" property="pltType" /> | 
|         <result column="ctn_type" property="ctnType" /> | 
|         <result column="loc_sts" property="locSts" /> | 
|         <result column="sheet_no" property="sheetNo" /> | 
|         <result column="crn_no" property="crnNo" /> | 
|         <result column="row1" property="row1" /> | 
|         <result column="bay1" property="bay1" /> | 
|         <result column="lev1" property="lev1" /> | 
|         <result column="full_plt" property="fullPlt" /> | 
|         <result column="loc_type" property="locType" /> | 
|         <result column="loc_type1" property="locType1" /> | 
|         <result column="loc_type2" property="locType2" /> | 
|         <result column="loc_type3" property="locType3" /> | 
|         <result column="out_enable" property="outEnable" /> | 
|         <result column="io_time" property="ioTime" /> | 
|         <result column="first_time" property="firstTime" /> | 
|         <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="error_time" property="errorTime" /> | 
|         <result column="error_memo" property="errorMemo" /> | 
|         <result column="ctn_kind" property="ctnKind" /> | 
|         <result column="sc_weight" property="scWeight" /> | 
|         <result column="inv_wh" property="invWh" /> | 
|         <result column="mk" property="mk" /> | 
|         <result column="barcode" property="barcode" /> | 
|         <result column="Pdc_type" property="PdcType" /> | 
|         <result column="ctn_no" property="ctnNo" /> | 
|   | 
|     </resultMap> | 
|     <update id="updateLocSts"> | 
|         UPDATE asr_loc_mast SET loc_sts = #{locSts} WHERE loc_no = #{locNo} | 
|     </update> | 
|   | 
|     <select id="queryFreeLocMast" resultMap="BaseResultMap"> | 
|         select | 
|         * | 
|         from asr_loc_mast | 
|         where 1=1 | 
|         and row1 in | 
|         <foreach item="item" collection="rows" index="index"  separator="," open="(" close=")"> | 
|             #{item} | 
|         </foreach> | 
|         and ctn_no = | 
|         ( | 
|             select | 
|             top 1 | 
|             ctn_no | 
|             from ( | 
|                 select | 
|                 ctn_no, | 
|                 count(1) as count | 
|                 from asr_loc_mast | 
|                 where 1=1 | 
|                 and row1 in | 
|                 <foreach item="item" collection="rows" index="index"  separator="," open="(" close=")"> | 
|                     #{item} | 
|                 </foreach> | 
|                 and loc_sts = 'O' | 
|                 <if test="locType1 != null"> | 
|                     and loc_type1 = #{locType1} | 
|                 </if> | 
|                 and loc_no not in ('0100101', '0200101', '0300101', '1200701', '1300701', '1400701', '1900401', '2000401', '2100401') | 
|                 group by ctn_no | 
|             ) a | 
|             where count = #{rowsLen} | 
|             order by right(ctn_no, 2) + 0 asc, left(ctn_no, 3) + 0 asc | 
|         ) | 
|     </select> | 
|   | 
|     <select id="queryFreeLocMast0" resultMap="BaseResultMap"> | 
|         select | 
|         * | 
|         from asr_loc_mast | 
|         where 1=1 | 
|         and row1 in | 
|         <foreach item="item" collection="rows" index="index"  separator="," open="(" close=")"> | 
|             #{item} | 
|         </foreach> | 
|         and ctn_no = | 
|         ( | 
|             select | 
|             top 1 | 
|             ctn_no | 
|             from ( | 
|                 select | 
|                 ctn_no, | 
|                 count(1) as count | 
|                 from asr_loc_mast | 
|                 where 1=1 | 
|                 and row1 in | 
|                 <foreach item="item" collection="rows" index="index"  separator="," open="(" close=")"> | 
|                     #{item} | 
|                 </foreach> | 
|                 and loc_sts = 'O' | 
|                 <if test="locType1 != null"> | 
|                     and loc_type1 = #{locType1} | 
|                 </if> | 
|                 <choose> | 
|                     <when test="inoutEveryday != null and inoutEveryday"> | 
|                         AND bay1 < 11 | 
|                     </when> | 
|                     <otherwise> | 
|                         AND bay1 > 10 | 
|                     </otherwise> | 
|                 </choose> | 
|                 and loc_no not in ('0100101', '0200101', '0300101', '1200701', '1300701', '1400701', '1900401', '2000401', '2100401') | 
|                 group by ctn_no | 
|             ) a | 
|             where count = #{rowsLen} | 
|             order by right(ctn_no, 2) + 0 asc, left(ctn_no, 3) + 0 asc | 
|         ) | 
|     </select> | 
|   | 
| </mapper> |