把一个list分割成多个小的list

原文链接: http://www.cnblogs.com/DongJiaxin/p/10576811.html

 

在对Oracle数据库表使用 in() 查询的时候,in() 中的数据不能超过 1000 条的限制,

这时候我们就要在程序中对数据进行分割,分割成多个小于 1000 条的数据集,进行多次查询。

下面就是分割的代码:

   
    public static List> groupList(List list) {
        List> listGroup = new ArrayList>();
        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 newList = list.subList(i, i + toIndex);
            listGroup.add(newList);
        }
        return listGroup;
    }
 

 分割完后并不能直接用于sql语句,所以需要转换一下格式,遍历一下分割后的list,把list内存储的

数据拼接成字符串就可以了。

转载于:https://www.cnblogs.com/DongJiaxin/p/10576811.html

你可能感兴趣的:(把一个list分割成多个小的list)