mybatis in语句不能大于1000的问题及解决
更新时间:2023年11月03日 10:29:07 作者:不如递归
这篇文章主要介绍了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;
}总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
如何解决MySQL安装遇到Start service红叉问题
在安装MySQL时,若遇到StartService步骤打红叉无法继续,可通过计算机管理以管理员身份运行服务,找到MySQL服务,更改为本地系统账户登录,解决安装问题,此方法为实际操作经验,可供参考,确保安装顺利完成2024-10-10
MySQL中参数sql_safe_updates在生产环境的使用详解
这篇文章主要给大家介绍了关于MySQL中参数sql_safe_updates在生产环境使用的相关资料,并给大家分享了解决mysql sql_safe_updates不支持子查询更新的方法,分享出来供大家参考学习,需要的朋友们下面来一起看看吧。2017-11-11
定时备份mysql, 定时切割nginx access log的方法
定时备份mysql, 定时切割nginx access log的方法,需要的朋友可以参考下。2011-09-09


最新评论