mybatis多个区间处理方式(双foreach循环)
mybatis多个区间处理
如图:要实现车辆数不同区间查询条件
思路
a.前端传数组,数组里面放"1-5"String类型值
b.后端mybatis用双foreach循环解析
后端代码如下:
<!--图例车辆数区间-->
<if test="countCargoList != null and countCargoList.size>0" > and ( <foreach item="item" index="index" collection="countCargoList"> ( <foreach item="item2" index="index2" collection="item.split('-')"> <if test="index2%2==0"> sfi.count_cargo >= #{item2} </if> <if test="index2%2==1"> and sfi.count_cargo <= #{item2} </if> </foreach> ) <!--最后一次不用加or--> <if test="index != countCargoList.size-1" > or </if> </foreach> ) </if>
多个foreach同时使用问题
应用场景
1、多个表的数据一起删除的时候,有的时候不会建立外键,但主表的关联 表很多的时候,可以直接利用mybatis 进行多表删除。
注意事项
mybatis 中多个foreach 循环,第一次循环的collection 看到的值是一个(数组、list、map、对象,由collection的配置主导)。
第二次foreach 是直接copy第一个foreach的对象值,这个时候会一直累加对象。
解决方案
数组为例
dao层去掉@Param注解
void batchDeleteSysTransferRegist(String rowData[]);
mybatis
<delete id="batchDeleteSysTransferRegist" parameterType="string"> delete from sys_transfer_regist_item where transfer_regist_id in <foreach item="rowData" collection="array" open="(" separator="," close=")"> #{rowData} </foreach> ;delete from sys_transfer_regist_piece where transfer_regist_id in <foreach item="rowData1" collection="array" open="(" separator="," close=")"> #{rowData1} </foreach> ...... </delete>
切记;隔开。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
浅析Spring Boot中的spring-boot-load模块
spring-boot-loader模块允许我们使用java -jar archive.jar运行包含嵌套依赖jar的jar或者war文件,它提供了三种类启动器。下面通过本文给大家介绍spring-boot-load模块的相关知识,感兴趣的朋友一起看看吧2018-01-01如何使用Idea中的 Deployment 实现打包自动部署
这篇文章主要介绍了使用Idea中的 Deployment 实现打包自动部署,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08Spring Boot应用启动时自动执行代码的五种方式(常见方法)
Spring Boot为开发者提供了多种方式在应用启动时执行自定义代码,这些方式包括注解、接口实现和事件监听器,本文我们将探讨一些常见的方法,以及如何利用它们在应用启动时执行初始化逻辑,感兴趣的朋友一起看看吧2024-04-04java类中生成jfreechart,返回图表的url地址 代码分享
这篇文章介绍了java类中生成jfreechart,返回图表的url地址的代码,有需要的朋友可以参考一下2013-08-08Spring Cloud Gateway集成Sentinel流控详情
这篇文章主要介绍了Spring Cloud Gateway集成Sentinel流控详情,Sentinel支持对Spring Cloud Gateway、Zuul等主流的API Gateway进行限流,需要的朋友可以参考一下2022-09-09
最新评论