8.mybatis動態SQL模糊查詢 (多參數查詢,使用parameterType)


多參數查詢,使用parameterType。實例:

 

用戶User[id, name, age]

1.mysql建表並插入數據

2.Java實體類

public class User {
    
    public User() {
    }
    public User(int id, String name, int age) {
        super();
        this.id = id;
        this.name = name;
        this.age = age;
    }
    private int id;
    private String name;
    private int age;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
    
}

3.創建查詢參數實體類

/**
 * 模糊查詢User的類
 * @author Administrator
 *
 */
public class SelectUserCondition {
    
    private String name;//姓名
    private int minAge;//最小年齡
    private int maxAge;//最大年齡
    
    
    public SelectUserCondition() {
        super();
    }
    public SelectUserCondition(String name, int minAge, int maxAge) {
        super();
        this.name = name;
        this.minAge = minAge;
        this.maxAge = maxAge;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getMinAge() {
        return minAge;
    }
    public void setMinAge(int minAge) {
        this.minAge = minAge;
    }
    public int getMaxAge() {
        return maxAge;
    }
    public void setMaxAge(int maxAge) {
        this.maxAge = maxAge;
    }
    
}

4.sql查詢的配置文件selectUserMapper.xml

<mapper namespace="com.mlxs.mybatis.test7.selectUserMapper">
    <!-- 
        動態sql,模糊查詢  parameterType為查詢條件實體
  -->
  <select id="getConditionUser" parameterType="SelectUserCondition" resultType="User">
    SELECT * FROM users WHERE
<if test='name != "%null%"'> NAME LIKE #{name} AND </if> age BETWEEN #{minAge} AND #{maxAge}
  </select>

</mapper>

5.測試類:

/**
 * 動態sql模糊查詢
 * 
 * 注意:當name=null時,"%"+name+"%"=%null%
 * @author 魅力_小生
 *
 */
public class _Test7SelectConditionUser {
    
    @Test
    public void getConditionUser(){
        //創建session,設置事務為true
        SqlSession session = MyBatisUtil.getSessionFactory().openSession(true);
        String statement = "com.mlxs.mybatis.test7.selectUserMapper.getConditionUser";
        //定義查詢條件實體
        SelectUserCondition condition = new SelectUserCondition("%a%", 20, 100);
        List<User> ulist = session.selectList(statement, condition);
        System.out.println("userList--->"+ulist);
        session.close();
    }
}

6.結果:

userList--->[User [id=3, name=update2, age=100], User [id=5, name=add1, age=23]]


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM