王佳豪
2021-07-14 0142e910dffd0255a4a4a1192cedd2ba0b0e71ab
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
<?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.MatCodeDao">
 
<!-- mapper不支持sql语句嵌套时,采用sql片段包含方式,解决xml标签问题 -->
<sql id="matCodeConditionSql">    
        <if test="mat_no!=null and mat_no!='' ">
            and mat_no like '%' + #{mat_no} + '%'
        </if>
        <if test="mat_name!=null and mat_name!='' ">
            and (mat_name like '%' + #{mat_name} + '%'
            or barcode like '%' + #{mat_name} + '%'
            or str1 like '%' + #{mat_name} + '%'
            or str2 like '%' + #{mat_name} + '%'
            or str3 like '%' + #{mat_name} + '%'
            or str4 like '%' + #{mat_name} + '%'
            or str5 like '%' + #{mat_name} + '%'
            )
        </if>        
</sql>
 
<!-- 分页查询所有信息 -->
<select id="queryMatCodeList" parameterType="com.slcf.bean.MatCodeCondition" resultType="com.slcf.pojo.MatCodeBean">
select top (#{pageSize}) * from bas_mat_code 
<where>
    mat_no not in (select top ((#{pageNumber}-1)*#{pageSize}) mat_no from bas_mat_code 
    <where>
        1=1
        <include refid="matCodeConditionSql"></include>        
    </where>
    order by modi_time desc)
    <include refid="matCodeConditionSql"></include>
    <![CDATA[
        order by modi_time desc
    ]]>
</where>
</select>
 
<select id="getMatCodeCount" parameterType="com.slcf.bean.MatCodeCondition"    resultType="Integer">
select count(1) from bas_mat_code
<where>
<![CDATA[
    1=1
]]>
<include refid="matCodeConditionSql"></include>
</where>
</select>
 
<!-- 不分页查询所有信息,用于excel导出 -->
<select id="getMatCodeAll" parameterType="com.slcf.bean.MatCodeCondition" resultType="com.slcf.pojo.MatCodeBean">
select * from bas_mat_code 
<where>
    <![CDATA[
         1=1
     ]]>
    <include refid="matCodeConditionSql"></include>
    <![CDATA[
        order by modi_time desc
    ]]>
</where>
</select>
 
</mapper>