目录

我的学习分享

记录精彩的程序人生

mybatis xml中使用in的sql长度超过1000的解决办法

https://blog.csdn.net/qq_34169240/article/details/81331246
——————————————————————————————————————————————————————
Java开发中会出现一种情况,就是使用mybatis 的in语句的时候,in语句里面的数组大小不能大于1000.

可以通过以下方法解决:

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

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"> 	
        and id in 	<foreach collection="idsItem" item="id" open="(" separator="," close=")"> 		
            #{id} 	
        </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;
     }


作者:鲁青未
来源:CSDN
原文:https://blog.csdn.net/wangfei964279744/article/details/78352055
版权声明:本文为博主原创文章,转载请附上博文链接!