Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mybatis in语句不能大于1000

mybatis in语句不能大于1000的问题及解决

作者:不如递归

这篇文章主要介绍了mybatis in语句不能大于1000的问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Java开发中会出现一种情况,就是使用mybatis 的in语句的时候,in语句里面的数组大小不能大于1000.

通过以下方法解决

对于一个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) and 
		 (
                <foreach collection="ids" item="idsItem" separtor="or">
                	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;
    }

总结

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

您可能感兴趣的文章:
阅读全文