| <?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="zy.cloud.wms.manager.mapper.LocDetlMapper"> | 
|   | 
|     <!-- 通用查询映射结果 --> | 
|     <resultMap id="BaseResultMap" type="zy.cloud.wms.manager.entity.LocDetl"> | 
|         <result column="loc_no" property="locNo" /> | 
|         <result column="node_id" property="nodeId" /> | 
|         <result column="zpallet" property="zpallet" /> | 
|         <result column="anfme" property="anfme" /> | 
|         <result column="matnr" property="matnr" /> | 
|         <result column="maktx" property="maktx" /> | 
|         <result column="name" property="name" /> | 
|         <result column="specs" property="specs" /> | 
|         <result column="model" property="model" /> | 
|         <result column="batch" property="batch" /> | 
|         <result column="unit" property="unit" /> | 
|         <result column="barcode" property="barcode" /> | 
|         <result column="doc_id" property="docId" /> | 
|         <result column="doc_num" property="docNum" /> | 
|         <result column="cust_name" property="custName" /> | 
|         <result column="item_num" property="itemNum" /> | 
|         <result column="count" property="count" /> | 
|         <result column="weight" property="weight" /> | 
|         <result column="status" property="status" /> | 
|         <result column="create_by" property="createBy" /> | 
|         <result column="create_time" property="createTime" /> | 
|         <result column="update_by" property="updateBy" /> | 
|         <result column="update_time" property="updateTime" /> | 
|         <result column="memo" property="memo" /> | 
|   | 
|     </resultMap> | 
|   | 
|     <sql id="locDetlCondition"> | 
|         <if test="loc_no != null and loc_no != ''"> | 
|             and mld.loc_no like concat('%',#{loc_no},'%') | 
|         </if> | 
|         <if test="matnr != null and matnr != ''"> | 
|             and mld.matnr like concat('%',#{matnr},'%') | 
|         </if> | 
|         <if test="maktx != null and maktx != ''"> | 
|             and mld.maktx like concat('%',#{maktx},'%') | 
|         </if> | 
|         <if test="startTime!=null and endTime!=null"> | 
|             and mld.update_time between #{startTime} and #{endTime} | 
|         </if> | 
|     </sql> | 
|   | 
|     <select id="listByPage" resultMap="BaseResultMap"> | 
|         select * from | 
|         ( | 
|             SELECT | 
|             ROW_NUMBER() over (order by mld.create_time desc) as row, | 
|             mld.* | 
|             FROM man_loc_detl mld | 
|             LEFT JOIN man_node mn ON mld.node_id = mn.id | 
|             WHERE 1=1 | 
|             AND (CHARINDEX(#{node_id}, ','+mn.path+',') > 0 OR mn.id = #{node_id}) | 
|             <include refid="locDetlCondition"></include> | 
|         ) t where t.row between ((#{pageNumber}-1)*#{pageSize}+1) and (#{pageNumber}*#{pageSize}) | 
|     </select> | 
|   | 
|     <select id="listByPageCount" parameterType="java.util.Map" resultType="java.lang.Integer"> | 
|         select | 
|         count(1) | 
|         FROM man_loc_detl mld | 
|         LEFT JOIN man_node mn ON mld.node_id = mn.id | 
|         WHERE 1=1 | 
|         AND (CHARINDEX(#{node_id}, ','+mn.path+',') > 0 OR mn.id = #{node_id}) | 
|         <include refid="locDetlCondition"></include> | 
|     </select> | 
|   | 
|     <select id="selectByLocNoAndMatnr" resultMap="BaseResultMap"> | 
|         select top 1 * | 
|         from man_loc_detl | 
|         where 1=1 | 
|         and anfme > 0 | 
|         <if test="nodeId != null and nodeId != ''"> | 
|             and node_id = #{nodeId} | 
|         </if> | 
|         <if test="matnr != null and matnr != ''"> | 
|             and matnr = #{matnr} | 
|         </if> | 
|         order by create_time asc | 
|     </select> | 
|   | 
|     <select id="selectCountByMatnr" resultType="java.lang.Double"> | 
|        select sum(anfme) as count from man_loc_detl where 1=1 and matnr = #{matnr} | 
|     </select> | 
|   | 
|     <update id="reduceStock"> | 
|         update man_loc_detl | 
|         set anfme = anfme - #{anfme} | 
|         , update_time = getdate() | 
|         where 1=1 | 
|         and node_id = #{nodeId} | 
|         and matnr = #{matnr} | 
|     </update> | 
|   | 
|     <update id="incrementStock"> | 
|         update man_loc_detl | 
|         set anfme = anfme + #{anfme} | 
|         , update_time = getdate() | 
|         where 1=1 | 
|         and node_id = #{nodeId} | 
|         and matnr = #{matnr} | 
|     </update> | 
|   | 
|     <update id="removeStock"> | 
|         delete from man_loc_detl | 
|         where 1=1 | 
|         and node_id = #{nodeId} | 
|         and matnr = #{matnr} | 
|     </update> | 
|   | 
|     <select id="selectByPrior" resultMap="BaseResultMap"> | 
|         select | 
|         mld.* | 
|         from man_loc_detl mld | 
|         left join man_prior mp on mld.node_id = mp.node_id and mld.matnr = mp.matnr | 
|         where 1=1 | 
|         <if test="nodeId != null and nodeId != ''"> | 
|             and mld.node_id = #{nodeId} | 
|         </if> | 
|         <if test="matnr != null and matnr != ''"> | 
|             and mld.matnr = #{matnr} | 
|         </if> | 
|         and mld.anfme > 0 | 
|         and mp.status = 1 | 
|         order by mp.prio desc, mld.create_time asc | 
|     </select> | 
|   | 
| </mapper> |