Mybatis解决oracle in语句 1000个数限制的问题
2018-03-22 20:31:12
1475次阅读
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
相关话题
- 解决kindeditor中onkeydown不执行的问题
- 调整memcached value默认1M的限制
- SImpleImage解决图片压缩变红问题
- 解决安卓浏览器文本无法垂直居中的问题
- 解决一个意外错误使您无法删除该文件
- MyBatis动态SQL
- 解决root用户和普通用户的时区不一致的问题
- 解决IE浏览器不支持Spring MVC 文件下载的问题
- DateTimeFormatter替换SimpleDateFormat解决线程安全问题
- mybatis批量插入数据
- 网站“订阅”“关注”“收藏”这三个功能的区别
- vue使用provide/inject方式解决刷新当前页面问题
- Fabric.js Zoom in & Zoom out
- 解决手机竖拍照片旋转90度问题
- 解决Spring Boot+AngularJS因为跨域导致Session丢失问题