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

mybatis多个区间处理

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

mybatis多个区间处理方式(双foreach循环)_第1张图片

思路

a.前端传数组,数组里面放"1-5"String类型值            

b.后端mybatis用双foreach循环解析    

后端代码如下:

 


          and (
          
              (
            
                
                    sfi.count_cargo >= #{item2}
                
                
                    and sfi.count_cargo <= #{item2}
                
            
              )
              
              
                  or
              
          
          )
      

mybatis多个区间处理方式(双foreach循环)_第2张图片

mybatis多个区间处理方式(双foreach循环)_第3张图片

多个foreach同时使用问题

应用场景

1、多个表的数据一起删除的时候,有的时候不会建立外键,但主表的关联 表很多的时候,可以直接利用mybatis 进行多表删除。

注意事项

mybatis 中多个foreach 循环,第一次循环的collection  看到的值是一个(数组、list、map、对象,由collection的配置主导)。

第二次foreach 是直接copy第一个foreach的对象值,这个时候会一直累加对象。

解决方案

数组为例

dao层去掉@Param注解

void batchDeleteSysTransferRegist(String rowData[]);

mybatis


        delete from sys_transfer_regist_item  where transfer_regist_id in
        
            #{rowData}
        
        ;delete from sys_transfer_regist_piece  where transfer_regist_id in
        
            #{rowData1}
        
......
    

切记;隔开。

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

你可能感兴趣的:(mybatis多个区间处理方式(双foreach循环))