mybatis注解开发使用foreach方式

 更新时间:2024年08月20日 09:07:09   作者:寻梦太极  
这篇文章主要介绍了mybatis注解开发使用foreach方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

mybatis注解开发使用foreach

写法看代码

    @Select( " <script>" +
            " select id, user_id userId, batch_number batchNumber, unit_name unitName, word_detail wordDetail,word, score, create_time createTime " +
            " from word_practice_records where user_id =#{userId} and batch_number=#{batchNumber} and unit_name=#{unitName} and  word  in "+
            " <foreach collection='wordScoreViewList' open='(' item='wordScore' separator=',' close=')'> #{wordScore.word}</foreach> "+
            " </script>" )
    List<WordPracticeRecords> getLessThan40WordByWordList(@Param("userId") String userId, @Param( "batchNumber" )String batchNumber,
                                                          @Param( "unitName" ) String unitName, @Param( "wordScoreViewList" ) List<WordScoreView>  wordScoreViewList);

注意:

需要再前后增加<script></script> 标签

循环使用

<foreach collection='wordScoreViewList' open='(' item='wordScore' separator=',' close=')'> 
    #{wordScore.word}
</foreach>

mybatis中的foreach语句简介

mybatis中的foreach语句适用于多种业务场景,主要起的作用是迭代集合。

在实际应用场景中,使用一个正确的foreach能够提高执行效率,所以通过记录最近一次使用foreach的具体场景来了解foreach的具体实现。

Mybatis的foreach语法

通过业务层传入一个LIst集合,其中存放了一批id号,List list 随后我要对此集合中的id取出依次遍历,即写法如下

select * from user where 1=1
<if test="id != null">
    and id in
    <foreach item="item" index="index" collection="list"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

等同于以下的mysql写法:

select * from user where id in (1,2,3,4,5)

其中需要注意的是collection参数后面的值要与变量名保持一致,我这里为list则需要保持一致,关于这几个参数的详解在文末会有介绍。

进阶写法

假如我传过来的是一个以,为分隔符的连贯字符串,例如某个对象中有一个属性String extInfo = “1,2,3,4,5”,依然跟上述的业务场景一致,那我们就需要先将该字符串做处理之后再进行foreach迭代

select * from user where 1=1
<if test="extInfo != null">
    and id in
    <foreach item="item" index="index" collection="extInfo.split(',')"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

还有一种业务场景是针对Map的迭代,例如有一个key-value对应的是ids-List,我们也能通过foreach迭代该map下的ids键来实现

select * from user where 1=1
<if test="extInfo != null">
    and id in
    <foreach item="item" index="index" collection="ids"  open="(" separator="," close=")">
   		'#{item}'
	</foreach>
</if>

原理

上述的foreach应用场景主要解决了使用in语句迭代批量查询,迭代删除以及迭代编辑等批量操作,那其中的参数具体是什么意思呢。

  • item表示集合中每一个元素进行迭代时的别名
  • index表示索引
  • collection表示要迭代的集合
  • open表示前缀的拼接内容
  • separator表示迭代集合
  • close表示后缀的拼接内容

基本语法就包括了上述的6个参数,各个参数都代表着各自的含义,在实际应用中使用foreach迭代能够帮助我们完成各类批量操作。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java删除String中空格的多种解决方法汇总

    Java删除String中空格的多种解决方法汇总

    在Java中从字符串中删除空格有很多不同的方法,如trim,replaceAll等,下面这篇文章主要给大家介绍了关于Java删除String中空格的多种解决方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • Java中如何判断线程池任务已执行完成

    Java中如何判断线程池任务已执行完成

    这篇文章主要介绍了Java中如何判断线程池任务已执行完成,文章围绕主题展开详细相关资料,具有一定的参考价值需要的小伙伴可以参考以参考一下
    2022-05-05
  • windows下使用 intellij idea 编译 kafka 源码环境

    windows下使用 intellij idea 编译 kafka 源码环境

    这篇文章主要介绍了使用 intellij idea 编译 kafka 源码的环境,本文是基于windows下做的项目演示,需要的朋友可以参考下
    2021-10-10
  • Java动态编译与类加载实战详解

    Java动态编译与类加载实战详解

    本文详细介绍Java Compiler API、类加载机制、反射、代理、Instrumentation、OSGi、Spring BeanDefinition、热部署工具及安全策略等关键技术,并结合实际项目帮助开发者掌握动态类处理的完整流程与最佳实践,感兴趣的朋友跟随小编一起看看吧
    2025-09-09
  • 详解Java中switch的新特性

    详解Java中switch的新特性

    这篇文章主要介绍了Java中switch的新特性,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • springmvc html资源请求404的问题解决并分析

    springmvc html资源请求404的问题解决并分析

    这篇文章主要介绍了springmvc html资源请求404的问题解决并分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Spring 循环依赖之AOP实现详情

    Spring 循环依赖之AOP实现详情

    这篇文章主要介绍了Spring 循环依赖之AOP实现详情,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的盆友可以参考一下
    2022-07-07
  • Spring项目XML文件使用小结

    Spring项目XML文件使用小结

    这篇文章主要介绍了Spring项目XML文件使用常见介绍,主要包括项目pom文件,项目初始IOC容器及项目需要自动装配的代码详解,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • Redis集群与SSM整合使用方法

    Redis集群与SSM整合使用方法

    这篇文章主要介绍了Redis集群与SSM整合使用方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-12-12
  • Stream distinct根据list某个字段去重的解决方案

    Stream distinct根据list某个字段去重的解决方案

    这篇文章主要介绍了Stream distinct根据list某个字段去重,stream的distinct去重方法,是根据 Object.equals,和 Object.hashCode这两个方法来判断是否重复的,本文给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05

最新评论