开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 912|回复: 0
收起左侧

[android教程] 详解 MyBatis 的 foreach 语句

[复制链接]
结帖率:63% (5/8)
发表于 2017-9-5 13:00:07 | 显示全部楼层 |阅读模式   山东省济南市
本帖最后由 Sir雨轩 于 2017-9-5 13:02 编辑
  1. @Test
  2.     public void dynamicForeachTest() {
  3.         SqlSession session = Util.getSqlSessionFactory().openSession();
  4.         BlogMapper blogMapper = session.getMapper(BlogMapper.class);
  5.         List<Integer> ids = new ArrayList<Integer>();
  6.         ids.add(1);
  7.         ids.add(3);
  8.         ids.add(6);
  9.         List<Blog> blogs = blogMapper.dynamicForeachTest(ids);
  10.         for (Blog blog : blogs)
  11.             System.out.println(blog);
  12.         session.close();
  13.     }
复制代码

foreach 元素的属性主要有 item,index,collection,open,separator,close。


  • item 表示集合中每一个元素进行迭代时的别名,
  • index 指 定一个名字,用于表示在迭代过程中,每次迭代到的位置,
  • open 表示该语句以什么开始,
  • separator 表示在每次进行迭代之间以什么符号作为分隔 符,
  • close 表示以什么结束。


在使用 foreach 的时候最关键的也是最容易出错的就是 collection 属性,该属性是必须指定的,但是在不同情况 下,该属性的值是不一样的,主要有一下3种情况:


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

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

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


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


1.单参数 List 的类型:

  1. <select id="dynamicForeachTest" resultType="Blog">
  2.         select * from t_blog where id in
  3.         <foreach collection="list" index="index" item="item" open="(" separator="," close=")">
  4.             #{item}
  5.         </foreach>
  6. </select>
复制代码

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

  1. public List<Blog> dynamicForeachTest(List<Integer> ids);
复制代码

测试代码:

  1. @Test
  2.     public void dynamicForeachTest() {
  3.         SqlSession session = Util.getSqlSessionFactory().openSession();
  4.         BlogMapper blogMapper = session.getMapper(BlogMapper.class);
  5.         List<Integer> ids = new ArrayList<Integer>();
  6.         ids.add(1);
  7.         ids.add(3);
  8.         ids.add(6);
  9.         List<Blog> blogs = blogMapper.dynamicForeachTest(ids);
  10.         for (Blog blog : blogs)
  11.             System.out.println(blog);
  12.         session.close();
  13.     }
复制代码

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

  1. <select id="dynamicForeach2Test" resultType="Blog">
  2.         select * from t_blog where id in
  3.         <foreach collection="array" index="index" item="item" open="(" separator="," close=")">
  4.             #{item}
  5.         </foreach>
  6. </select>
复制代码

上述collection为array,对应的Mapper代码:

  1. public List<Blog> dynamicForeach2Test(int[] ids);
复制代码

对应的测试代码:

  1. @Test
  2.     public void dynamicForeach2Test() {
  3.         SqlSession session = Util.getSqlSessionFactory().openSession();
  4.         BlogMapper blogMapper = session.getMapper(BlogMapper.class);
  5.         int[] ids = new int[] {1,3,6,9};
  6.         List<Blog> blogs = blogMapper.dynamicForeach2Test(ids);
  7.         for (Blog blog : blogs)
  8.             System.out.println(blog);
  9.         session.close();
  10.     }
复制代码

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

  1. <select id="dynamicForeach3Test" resultType="Blog">
  2.         select * from t_blog where title like "%"#{title}"%" and id in
  3.         <foreach collection="ids" index="index" item="item" open="(" separator="," close=")">
  4.             #{item}
  5.         </foreach>
  6. </select>
复制代码
上述collection的值为ids,是传入的参数Map的key,对应的Mapper代码:
  1. public List<Blog> dynamicForeach3Test(Map<String, Object> params);
复制代码
对应测试代码:
  1. @Test
  2.     public void dynamicForeach3Test() {
  3.         SqlSession session = Util.getSqlSessionFactory().openSession();
  4.         BlogMapper blogMapper = session.getMapper(BlogMapper.class);
  5.         final List<Integer> ids = new ArrayList<Integer>();
  6.         ids.add(1);
  7.         ids.add(2);
  8.         ids.add(3);
  9.         ids.add(6);
  10.         ids.add(7);
  11.         ids.add(9);
  12.         Map<String, Object> params = new HashMap<String, Object>();
  13.         params.put("ids", ids);
  14.         params.put("title", "中国");
  15.         List<Blog> blogs = blogMapper.dynamicForeach3Test(params);
  16.         for (Blog blog : blogs)
  17.             System.out.println(blog);
  18.         session.close();
  19.     }
复制代码


您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表