java中将List切割执行

本文介绍如何使用Guava库中的Lists.partition方法对大型列表进行分批处理,以适应数据库批量操作的需求,并展示了不同场景下的应用实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

现在有一个比较大的list,比如请求过来了一个list,它里面有1000个数据需要入库,如果我一下把1000条数据全部插入,可能数据库会扛不住,或者我调其它公司的推送,比如调华为推送,它只允许我一次最多推100条数据,那么需要对传入的大list进行切分,分段执行。

需要引入google的guava jar包,用到的api是Lists.partition

示例如下:

/**
 * 描述:Guava工具类partition使用
 */
public class Lists_Partition {


    Logger log = LoggerFactory.getLogger(Lists_Partition.class);


    public static void main(String[] args) {

        //step.1 集合切割正常逻辑
        List<Integer> numList = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8);

        List<List<Integer>> partList = Lists.partition(numList, 3);
        if (!CollectionUtils.isEmpty(partList)) {
            for (List<Integer> list : partList) {
                System.out.println(list.toString());
            }
        }

        //step.2 切割数量大于集合数量
        List<Integer> numList2 = Lists.newArrayList(1);
        List<List<Integer>> partList2 = Lists.partition(numList2, 3);
        if (!CollectionUtils.isEmpty(partList2)) {
            for (List<Integer> list : partList2) {
                System.out.println(list.toString());
            }
        }


        //step.3 修改切割后的集合,检查原集合是否被修改
        List<Integer> numList3 = Lists.newArrayList(1,2,3,4,5,6,7,89,9);

        List<List<Integer>> partList3 = Lists.partition(numList3, 3);
        if (!CollectionUtils.isEmpty(partList3)) {
            for (List<Integer> list : partList3) {
                for(int i=0,len = list.size();i<len;i++){
                    list.set(i,8);
                }
            }
            //打印原集合
            System.out.println(numList3.toString());

        }

        //注意:partition返回的是原list的subview.视图,即原list改变后,partition之后的结果也会随着改变

        //step.4 List.partition()在真实项目中的运用
        List<Integer> numList4 = Lists.newArrayList(1, 2, 3, 4, 5, 6, 7, 8, 9);

        List<List<Integer>> partList4 = Lists.partition(numList4, 100);
        if (!CollectionUtils.isEmpty(partList4)) {

            for (List<Integer> list : partList4) {
                //将切割的集合按照固定数量查询数据库
                //xxxx.findById(list)
                //select * from user u where u.id in (1,2,3 ....) 这里的id数量不要超过100个
            }

        }


    }


}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值