在对Oracle数据库表使用 in() 查询的时候,in() 中的数据不能超过 1000 条的限制,
这时候我们就要在程序中对数据进行分割,分割成多个小于 1000 条的数据集,进行多次查询。
下面就是分割的代码:
public static List<List<String>> groupList(List<String> list) { List<List<String>> listGroup = new ArrayList<List<String>>(); int listSize = list.size(); //子集合的长度,比如 500 int toIndex = 500; for (int i = 0; i < list.size(); i += 500) { if (i + 500 > listSize) { toIndex = listSize - i; } List<String> newList = list.subList(i, i + toIndex); listGroup.add(newList); } return listGroup; }
分割完后并不能直接用于sql语句,所以需要转换一下格式,遍历一下分割后的list,把list内存储的
数据拼接成字符串就可以了。