Mybatis解决oracle in语句 1000个数限制的问题

2018-03-22 20:31:12
1388次阅读
0个评论
Oralce in 语句中当in(1,2,3...) 条件数量大于1000将会报错。

如果我们把in拆分成多个in就可以解决这个问题。

对于一个List<String> ids 大小大于1000的list而言,使用getSumArrayList方法,获取List<List<String>> 对象


List<List<String>> idParams = shareEpdService.getSumArrayList(idParam);  
            Map<String, Object> mapNew = new HashMap<>();  
            mapNew.put("ids", idParams );  
            settlementCostMapper.submitDataByCondition(mapNew)

调用mybatis的方法,做如下处理:


<update id="submitDataByCondition">  
        UPDATE 表名 SET STATE=1 WHERE STATE IN (-1,0)   
         <foreach collection="ids" item="idsItem">  
                <span style="white-space:pre;"> </span>and id  in  
                <span style="white-space:pre;"> </span><foreach collection="idsItem" item="id" open="(" separator="," close=")">  
                   <span style="white-space:pre;">      </span>#{id}  
                <span style="white-space:pre;"> </span></foreach>  
            </foreach>  
    </update>

getSumArrayList方法如下:



public <T>  List<List<T>> getSumArrayList(List<T> list){  
        List<List<T>> objectlist = new ArrayList<>();  
        int iSize = list.size()/1000;  
        int iCount = list.size()%1000;  
        for(int i=0;i<=iSize;i++){  
            List<T> newObjList = new ArrayList<>();  
            if(i==iSize){  
                for(int j =i*1000;j<i*1000+iCount;j++ ){  
                    newObjList.add(list.get(j));  
                }  
            }else{  
                for(int j =i*1000;j<(i+1)*1000;j++ ){  
                    newObjList.add(list.get(j));  
                }  
            }  
            if(newObjList.size()>0){  
                objectlist.add(newObjList);  
            }  
        }  
        return objectlist;  
    }
收藏00

登录 后评论。没有帐号? 注册 一个。