Java开发中会出现一种情况,就是使用mybatis 的in语句的时候,in语句里面的数组大小不能大于1000.
可以通过以下解决:
定义一个数据拆分的方法:
public <T> List<List<T>> getSumArrayList(List<T> list){
List<List<T>> objects = 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){
objects.add(newObjList);
}
}
return objects;
}
mybatis的xml:
<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>