本博客介绍oracle select in超过1000条数据的解决方法,java框架是采用mybatis的,这可以说是一种比较常见的错误:select * from A where id in(...)
,oracle官方函数做了限定,in里的参数只能1000个,所以超过1000个参数就会报错,解决方法是将集合分为每个集合1000的小集合,然后用or拼起来select * from A where id in(1,2,...,1000) or id in (1001,1002,2000)...
,好的,根据这个sql,下面介绍一下orm空间为mybatis的项目里怎么解决
java代码只要获取参数进行集合拆分就可以:
举个例子,下面是一种方法
Listvalues = new ArrayList ();String[] configSeqArray = StringUtils.split(configSeq,',');for (String str : configSeqArray) { values.add(str);}List > configSeqs = CollectionUtil.splitCollection(values, 1000);
复制公司同事写的集合拆分的方法
import java.util.ArrayList;import java.util.Collection;import java.util.List;public class CollectionUtils { public static List> splitCollection(Collection values , int size) { List > result = new ArrayList >(); if(values.size() <= size ){ result.add(values); }else{ int count =0; Collection subCollection= null; for(String s:c){ if(subCollection == null){ subColletion = new ArrayList (); result.add(subColletion); } subCollection.add(s); count++; if(count == size){ count =0; subCollectiion = null; } } } }}
Mybatis的代码:
select * from t_config_related#{seq}