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(); } }