MyBatis的foreach语句详解

foreach的主要用在构建in条件中,它可以在SQL语句中进行迭代一个集合。

foreach元素的属性主要有 itemindexcollectionopenseparatorclose

item表示集合中每一个元素进行迭代时的别名,

index指 定一个名字,用于表示在迭代过程中,每次迭代到的位置,

open表示该语句以什么开始,separator表示在每次进行迭代之间以什么符号作为分隔 符,

close表示以什么结束,在使用foreach的时候最关键的也是最容易出错的就是collection属性,

该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:

 

(1)如果传入的是单参数且参数类型是一个List的时候,collection属性值为list

(2)如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array

(3)如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,mapkey就是参数名,所以这个时候collection属性值就是传入的Listarray对象在自己封装的map里面的key

 

下面分别来看看上述三种情况的示例代码:

1.单参数List的类型  

    <select id="dynamicForeachTest" resultType="Blog">  

        select * from t_blog where id in  

        <foreach collection="list" index="index" item="item" open="(" separator="," close=")">  

            #{item}  

        </foreach>  

    </select>  

 

 

上述collection的值为list,对应的Mapper是这样的  

public List<Blog> dynamicForeachTest(List<Integer> ids);  

测试代码:  

    @Test  

    public void dynamicForeachTest() {  

        SqlSession session = Util.getSqlSessionFactory().openSession();  

        BlogMapper blogMapper = session.getMapper(BlogMapper.class);  

        List<Integer> ids = new ArrayList<Integer>();  

        ids.add(1);  

        ids.add(3);  

        ids.add(6);  

        List<Blog> blogs = blogMapper.dynamicForeachTest(ids);  

        for (Blog blog : blogs)  

            System.out.println(blog);  

        session.close();  

    }  

2.单参数array数组的类型:  

  <select id="dynamicForeach2Test" resultType="Blog">  

      select * from t_blog where id in  

      <foreach collection="array" index="index" item="item" open="(" separator="," close=")">  

            #{item}  

        </foreach>  

  </select>  

 

 

上述collectionarray,对应的Mapper代码:  

public List<Blog> dynamicForeach2Test(int[] ids);  

对应的测试代码:  

    @Test  

    public void dynamicForeach2Test() {  

        SqlSession session = Util.getSqlSessionFactory().openSession();  

        BlogMapper blogMapper = session.getMapper(BlogMapper.class);  

        int[] ids = new int[] {1,3,6,9};  

        List<Blog> blogs = blogMapper.dynamicForeach2Test(ids);  

        for (Blog blog : blogs)  

            System.out.println(blog);  

        session.close();  

    }  

3.把参数封装成Map的类型  

  <select id="dynamicForeach3Test" resultType="Blog">  

        select * from t_blog where title like "%"#{title}"%" and id in  

        <foreach collection="ids" index="index" item="item" open="(" separator="," close=")">  

            #{item}  

        </foreach>  

   </select>  

 

 

上述collection的值为ids,是传入的参数Mapkey,对应的Mapper代码:  

public List<Blog> dynamicForeach3Test(Map<String, Object> params);  

对应测试代码:  

    @Test  

    public void dynamicForeach3Test() {  

        SqlSession session = Util.getSqlSessionFactory().openSession();  

        BlogMapper blogMapper = session.getMapper(BlogMapper.class);  

        final List<Integer> ids = new ArrayList<Integer>();  

        ids.add(1);  

        ids.add(2);  

        ids.add(3);  

        ids.add(6);  

        ids.add(7);  

        ids.add(9);  

        Map<String, Object> params = new HashMap<String, Object>();  

        params.put("ids", ids);  

        params.put("title", "中国");  

        List<Blog> blogs = blogMapper.dynamicForeach3Test(params);  

        for (Blog blog : blogs)  

            System.out.println(blog);  

        session.close();  

    } 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值