mybatis多个区间处理方式(双foreach循环)

作者:ejQiu 时间:2023-11-26 09:01:42 

mybatis多个区间处理

如图:要实现车辆数不同区间查询条件

mybatis多个区间处理方式(双foreach循环)

思路

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>

mybatis多个区间处理方式(双foreach循环)

mybatis多个区间处理方式(双foreach循环)

多个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>

切记;隔开。

来源:https://www.cnblogs.com/ejQiu-123/p/11448175.html

标签:mybatis,区间,foreach,循环
0
投稿

猜你喜欢

  • Android string.xml中的替换方法

    2021-11-10 11:47:56
  • java实现快速打字游戏

    2022-11-05 11:16:38
  • java的Arrays工具类实战

    2023-08-21 15:46:36
  • 利用ThreadLocal实现一个上下文管理组件

    2022-04-16 03:42:23
  • C#中三种Timer计时器的详细用法

    2022-12-14 13:52:34
  • android开发实现文件读写

    2022-08-03 09:46:18
  • Android实现扫一扫识别数字功能

    2021-09-27 09:30:57
  • Java正则验证电话,手机,邮箱,日期,金额的方法示例

    2021-06-25 22:37:46
  • android通过usb读取U盘的方法

    2023-03-14 07:43:25
  • Android 使用PDF.js浏览pdf的方法示例

    2021-12-08 06:11:41
  • Java中Set&List的迭代器实现步骤解析

    2021-05-27 16:47:06
  • 浅谈String.split()遇到空字符串的几种情况

    2021-11-24 00:18:38
  • RecyclerView实现纵向和横向滚动

    2023-04-03 14:50:44
  • Java中类的加载顺序执行结果

    2022-03-12 18:12:35
  • 基于WPF实现简单的文件夹比较工具

    2023-11-15 16:08:34
  • 一步步教你如何使用Java实现WebSocket

    2023-06-07 04:18:20
  • java中的基础运算符

    2022-06-23 04:19:38
  • mybatis中使用大于小于等于的正确方法

    2021-10-09 03:52:56
  • 关于maven打包时的报错: Return code is: 501 , ReasonPhrase:HTTPS Required

    2022-09-09 00:50:51
  • 如何在Spring Boot中使用MQTT

    2023-10-08 20:39:13
  • asp之家 软件编程 m.aspxhome.com