一、编写接口方法:
package com.mybatis.mapper; import java.util.List; import org.apache.ibatis.annotations.Param; import com.mybatis.bean.Employee; public interface EmployeeMapperDynamicSQL { //查询员工id'在给定集合中的 public List<Employee> getEmpsByConditionForeach(@Param("ids")List<Integer> ids); }
二、编写sql映射文件
<?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.mybatis.mapper.EmployeeMapperDynamicSQL"> <!--public List<Employee> getEmpsByConditionForeach(List<Integer> ids); --> <select id="getEmpsByConditionForeach" resultType="com.mybatis.bean.Employee"> select * from tbl_employee <!-- 测试用例: select * from tbl_employee where id in (1,2,3) collection:指定要遍历的集合: list类型的参数会特殊处理封装在map中,map的key就叫list item:将当前遍历出的元素赋值给指定的变量 separator:每个元素之间的分隔符 open:遍历出所有结果拼接一个开始的字符 close:遍历出所有结果拼接一个结束的字符 index:索引。遍历list的时候是index就是索引,item就是当前值 遍历map的时候index表示的就是map的key,item就是map的值 #{变量名}就能取出变量的值也就是当前遍历出的元素 --> <foreach collection="ids" item="item_id" separator="," open="where id in(" close=")"> #{item_id} </foreach> </select> </mapper>
三、编写Junit测试
List<Employee> list = mapper.getEmpsByConditionForeach(Arrays.asList(1,2)); for (Employee emp : list) { System.out.println(emp); }