iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >foreach与collection怎么在mybatis 中使用
  • 900
分享到

foreach与collection怎么在mybatis 中使用

mybatisforeachcollection 2023-05-31 00:05:51 900人浏览 薄情痞子
摘要

foreach与collection怎么在mybatis 中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。foreach的主要用在构建in条件中,它可以在sql语句中进

foreach与collection怎么在mybatis 中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

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

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

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

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

    1. 如果传入的是单参数且参数类型是一个List的时候,collection属性值为list
    2. 如果传入的是单参数且参数类型是一个array数组的时候,collection的属性值为array
    3. 如果传入的参数是多个的时候,我们就需要把它们封装成一个Map了,当然单参数也可

以封装成map,实际上如果你在传入参数的时候,在breast里面也是会把它封装成一个Map的,map的key就是参数名,所以这个时候collection属性值就是传入的List或array对象在自己封装的map里面的key 下面分别来看看上述三种情况的示例代码:

单参数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 dynamicForeachTest(List ids);

测试代码:

@Test   public void dynamicForeachTest() {     SqlSession session = Util.getSqlSessionFactory().openSession();        BlogMapper blogMapper = session.getMapper(BlogMapper.class);      List ids = new ArrayList();      ids.add(1);      ids.add(3);      ids.add(6);     List blogs = blogMapper.dynamicForeachTest(ids);     for (Blog blog : blogs)       System.out.println(blog);     session.close();   }

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

 <select id="dynamicForeach3Test" resultType="Blog">   select * from t_blog where id in   <foreach collection="array" index="index" item="item" open="(" separator="," close=")">     #{item}   </foreach> </select>

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

public List dynamicForeach3Test(int[] ids);

对应的测试代码:

@Test public void dynamicForeach3Test() {     SqlSession session = Util.getSqlSessionFactory().openSession();     BlogMapper blogMapper = session.getMapper(BlogMapper.class);     int[] ids = new int[] {1,3,6,9};     List blogs = blogMapper.dynamicForeach3Test(ids);     for (Blog blog : blogs)     System.out.println(blog);       session.close(); }

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

 <select id="dynamicForeach4Test" 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,是传入的参数Map的key,对应的Mapper代码:

public List dynamicForeach4Test(Map params);

对应测试代码:

@Test  public void dynamicForeach4Test() {    SqlSession session = Util.getSqlSessionFactory().openSession();     BlogMapper blogMapper = session.getMapper(BlogMapper.class);     final List ids = new ArrayList();     ids.add(1);     ids.add(2);     ids.add(3);     ids.add(6);     ids.add(7);     ids.add(9);    Map params = new HashMap();     params.put("ids", ids);     params.put("title", "中国");    List blogs = blogMapper.dynamicForeach4Test(params);     for (Blog blog : blogs)       System.out.println(blog);     session.close();   }

关于foreach与collection怎么在mybatis 中使用问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: foreach与collection怎么在mybatis 中使用

本文链接: https://www.lsjlt.com/news/222545.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • foreach与collection怎么在mybatis 中使用
    foreach与collection怎么在mybatis 中使用?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。foreach的主要用在构建in条件中,它可以在SQL语句中进...
    99+
    2023-05-31
    mybatis foreach collection
  • Mybatis中association和collection怎么用
    这篇文章将为大家详细讲解有关Mybatis中association和collection怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。association和collection用法1.单个关联查询...
    99+
    2023-06-29
  • js中forEach怎么使用及forEach与for的区别是什么
    本篇内容介绍了“js中forEach怎么使用及forEach与for的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、定义和用法...
    99+
    2023-06-29
  • Mybatis中动态SQL,if,where,foreach怎么用
    这篇文章主要为大家展示了“Mybatis中动态SQL,if,where,foreach怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mybatis中动态SQL,if,wher&#...
    99+
    2023-05-30
    mybatis sql
  • forEach在项目中怎么用
    这篇文章给大家分享的是有关forEach在项目中怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 forEach会改变原始数组  被forEach循环的数组不能够...
    99+
    2022-10-19
  • perl中foreach怎么使用
    在 Perl 中,`foreach` 用于迭代数组或哈希中的每个元素。它的语法如下:对于数组:```perlforeach my $...
    99+
    2023-09-26
    perl
  • foreach循环怎么在java8项目中使用
    这篇文章将为大家详细讲解有关foreach循环怎么在java8项目中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.首先遍历一个List方式1.一开始是这样的:public stati...
    99+
    2023-05-31
    java foreach循环 fo
  • 怎么在Springboot中使用mybatis
    今天就跟大家聊聊有关怎么在Springboot中使用mybatis,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。前期工作1.导入mybatis整合依赖<!-- &nb...
    99+
    2023-06-14
  • 怎么在mybatis中使用resultmap
    本篇文章给大家分享的是有关怎么在mybatis中使用resultmap,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。SQL 映射XML 文件是所有sql语句放置的地方。需要定义...
    99+
    2023-05-31
    mybatis resultmap
  • mybatis怎么使用foreach遍历list集合或者array数组
    这篇文章主要介绍“mybatis怎么使用foreach遍历list集合或者array数组”,在日常操作中,相信很多人在mybatis怎么使用foreach遍历list集合或者array数组问题上存在疑惑,小编查阅了各式资料,整理出简单好用的...
    99+
    2023-06-20
  • 怎么在php中使用foreach遍历类对象
    怎么在php中使用foreach遍历类对象?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。php有什么特点1、执行速度快。2、具有很好的开放性和可扩展性。3、PHP支持多种主...
    99+
    2023-06-14
  • 怎么在Spring Boot中使用MyBatis
    这篇文章将为大家详细讲解有关怎么在Spring Boot中使用MyBatis,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。orm框架的本质是简化编程中操作数据库的编码,发展到现在基本上就剩两...
    99+
    2023-05-31
    springboot mybatis
  • 怎么在php中使用foreach循环遍历数组
    本篇文章为大家展示了怎么在php中使用foreach循环遍历数组,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。PHP开发环境搭建工具有哪些一、phpStudy,是一个新手入门最常用的开发环境。二、W...
    99+
    2023-06-14
  • Mybatis怎么与Spring结合使用
    Mybatis怎么与Spring结合使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。所需要用到的其他工具或技术:项目管理工具 : Maven前台WEB展示:JSP其他框架:S...
    99+
    2023-05-31
    mybatis spring
  • 怎么在java中使用mybatis框架
    怎么在java中使用mybatis框架?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程...
    99+
    2023-06-14
  • MyBatis映射文件中parameterType与resultType怎么使用
    这篇“MyBatis映射文件中parameterType与resultType怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看...
    99+
    2023-07-06
  • mybatis使用foreach查询不出结果也不报错的问题怎么解决
    本篇内容介绍了“mybatis使用foreach查询不出结果也不报错的问题怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!foreac...
    99+
    2023-06-29
  • 怎么在MyBatis中使用动态SQL标签
    这篇文章将为大家详细讲解有关怎么在MyBatis中使用动态SQL标签,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1.MyBatis动态SQLMyBatis 的强大特性之一便是它的动态 SQ...
    99+
    2023-06-14
  • 怎么在mybatis中使用oracle添加数据
    这期内容当中小编将会给大家带来有关怎么在mybatis中使用oracle添加数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。查询查询语句都是正常的,但是需要注意的是oracle数据库在查询的时候,表名使...
    99+
    2023-06-14
  • 怎么在Java8中使用foreach循环获取对象的index下标
    这期内容当中小编将会给大家带来有关怎么在Java8中使用foreach循环获取对象的index下标,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。在Java8中,我们经常使用lambada表达式进行fore...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作