王佳豪
2021-06-26 718f604deb342b0bee6c588bb44e22ced3371fb8
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?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.slcf.dao.LocDetailDao">
 
<!-- mapper不支持sql语句嵌套时,采用sql片段包含方式,解决xml标签问题 -->
<sql id="locDetailConditionSql">    
        <if test="loc_no!=null and loc_no!='' ">
            and a.loc_no like '%' + #{loc_no} + '%'
        </if>
        <if test="loc_sts!=null and loc_sts!='' ">
            and loc_sts = #{loc_sts}
        </if>
        <if test="maktx!=null and maktx!='' ">
            and maktx like '%' + #{maktx} + '%'
        </if>
        <if test="matnr!=null and matnr!='' ">
            and (a.matnr like '%' + #{matnr} + '%'
            or matnr like '%' + #{matnr} + '%'
            or lgnum like '%' + #{matnr} + '%'
            or tbnum like '%' + #{matnr} + '%'
            or tbpos like '%' + #{matnr} + '%'
            or zmatid like '%' + #{matnr} + '%'
            or maktx like '%' + #{matnr} + '%'
            or werks like '%' + #{matnr} + '%'
            or anfme like '%' + #{matnr} + '%'
            or altme like '%' + #{matnr} + '%'
            or zpallet like '%' + #{matnr} + '%'
            or bname like '%' + #{matnr} + '%'
            )
        </if>    
</sql>
 
<select id="queryLocDetailList" parameterType="com.slcf.bean.LocDetailCondition" resultType="com.slcf.pojo.LocDetailBean">
select * from ( 
select a.*,ROW_NUMBER() OVER(Order by a.appe_time,a.matnr,a.loc_no) as rowid
 from asr_loc_detl a left join asr_loc_mast c on a.loc_no=c.loc_no
<where>
    1=1
     <include refid="locDetailConditionSql"></include>
</where>
 ) as a
<where>
    rowid between ((#{pageNumber}-1)*#{pageSize}+1) and (#{pageNumber}*#{pageSize})
    <![CDATA[
        order by a.appe_time,a.matnr,a.loc_no asc
    ]]>
</where> 
</select>
 
<!-- <select id="queryLocDetailList" parameterType="com.slcf.bean.LocDetailCondition" resultType="com.slcf.pojo.LocDetailBean"> -->
<!-- select * from (  -->
<!-- select t1.*,t2.mat_name mat_name,str1,str2,loc_sts,qty as retrieve_qty,ROW_NUMBER() OVER(Order by t1.loc_no,t1.mat_no) as rowid -->
<!--  from asr_loc_detl t1 left join bas_mat_code t2  on t1.mat_no=t2.mat_no -->
<!--                        left join asr_loc_mast t3 on t1.loc_no=t3.loc_no -->
<!--  ) as a -->
<!-- <where> -->
<!--     rowid between ((#{pageNumber}-1)*#{pageSize}+1) and (#{pageNumber}*#{pageSize}) -->
<!--     <include refid="locDetailConditionSql"></include> -->
<!--     <![CDATA[ -->
<!--         order by a.loc_no,a.mat_no asc -->
<!--     ]]> -->
<!-- </where> -->
<!-- </select> -->
 
<!-- <select id="queryLocDetailList" parameterType="com.slcf.bean.LocDetailCondition" resultType="com.slcf.pojo.LocDetailBean"> -->
<!-- select top (#{pageSize}) a.*,b.mat_name mat_name,b.str1,b.str2 -->
<!-- from asr_loc_detl a left join bas_mat_code b  on a.mat_no=b.mat_no  -->
<!-- <where> -->
<!--     a.mat_no not in (select top ((#{pageNumber}-1)*#{pageSize}) a.mat_no from asr_loc_detl a left join bas_mat_code b  on a.mat_no=b.mat_no  -->
<!--     <where> -->
<!--         1=1 -->
<!--         <include refid="locDetailConditionSql"></include>         -->
<!--     </where> -->
<!--     order by a.loc_no,a.mat_no asc) -->
<!--     <include refid="locDetailConditionSql"></include> -->
<!--     <![CDATA[ -->
<!--         order by a.loc_no,a.mat_no asc -->
<!--     ]]> -->
<!-- </where> -->
<!-- </select> -->
 
<select id="getLocDetailCount" parameterType="com.slcf.bean.LocDetailCondition"    resultType="Integer">
select count(1) from asr_loc_detl a left join asr_loc_mast c on a.loc_no=c.loc_no
<where>
<![CDATA[
    1=1
]]>
<include refid="locDetailConditionSql"></include>
</where>
</select>
 
<!-- 不分页查询所有信息,用于excel导出 -->
<select id="getLocDetailAll" parameterType="com.slcf.bean.LocDetailCondition" resultType="com.slcf.pojo.LocDetailBean">
select a.*
 from asr_loc_detl a
<where>
    <![CDATA[
         1=1
     ]]>
    <include refid="locDetailConditionSql"></include>
    <![CDATA[
         order by a.appe_time,a.matnr,a.loc_no asc
     ]]> 
</where>
</select>
 
</mapper>