1、if标签

实体类Product的字段比较多的时候,为了应付各个字段的查询,那么就需要写多条SQL语句,这样就变得难以维护。

此时,就可以使用MyBatis动态SQL里的if标签

<select id="listProduct" resultType="Product">
    select * from product_table
    <if test="name!=null">
        where name like concat('%',#{name},'%')
    </if>
</select>

这种写法,如果没有传递参数name,那么就查询所有,如果有name就进行模糊查询。

这样就定义了一条SQL语句,应付了多种情况。

TestMyBatis测试如下:

package com.demo;
import java.io.IOException;
import java.io.InputSteam;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.ibatis.io.Resouces;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import com.demo.pojo.Product;

public class TestMyBatis{
    public static void main(String[] args) throws IOException{
        String resouce="mybatis-config.xml";
        InputSteam inputStream=Resources.getResourceAsStream(resource);
        SqlSessionFactory sqlSessionFactory =new SqlSessionFactoryBuilder().build(inputStream);
        SqlSession session=sqlSessionFactory.openSession();
        
        System.out.println("查询所有的数据");
        List<Product> list1=session.selectList("listProduct");
        for(Product p:list1){
            System.out.println(p);
        }
        
        System.out.println("模糊查询");
        Map<String,Object> params=new HashMap<>();
        params.put("name","a");
        List<Product> list2=session.selectList("listProduct",params);
        for(Product p:list2){
            System.out.println(p);
        }
        
        session.commit();
        session.close();
        
    }
}
View Code

相关文章: