JAVA数据批处理,按组切分方式

文章提供了两种Java方法,用于将列表数据按指定数量或段数进行分隔,以应对数据库IN()操作不超过1000个元素的限制。第一种是按每段数量分段,考虑了除不尽的情况;第二种是按固定段数分段,多出的数据放在最后一段。这些方法有助于优化批量操作的流程。
摘要由CSDN通过智能技术生成

昨天遇到个批操作,数据库in()内不可超过1000个,故需要分批次处理,现将切分方法记录如下:

    /**
     * 分隔数组 根据每段数量分段
     *
     * @param data 被分隔的数组
     * @param count 每段数量
     *
     * @return
     */
    public static<T> List<List<T>> subListByCount(List<T> data, int count) {
        List<List<T>> result = new ArrayList<>();
        int size = data.size();// 数据长度
        if (size > 0 && count > 0) {
            int segments = size / count;
            /**
             * 1.整除,分隔为segments 段
             * 2.除不尽, 分隔为segments + 1 段
             */
            segments = size % count == 0 ? segments : segments + 1;
            List<T> cutList = null;// 每段List
            for (int i = 0; i < segments; i++) {
                if (i == segments - 1) {
                    cutList = data.subList(count * i, size);
                } else {
                    cutList = data.subList(count * i, count * (i + 1));
                }
                result.add(cutList);
            }
        } else {
            result.add(data);
        }
        return result;
    }

   /**
     * 分隔数组 根据段数分段 <多出部分在最后一个数组>
     *
     * @param data 被分隔的数组
     * @param segments 需要分隔的段数
     *
     * @return
     */
    public static<T> List<List<T>> subListBySegment(List<T> data, int segments) {
        List<List<T>> result = new ArrayList<>();
        int size = data.size();// 数据长度
        if (size > 0 && segments > 0) {
            int count = size / segments;
            List<T> cutList = null;
            for (int i = 0; i < segments; i++) {
                if (i == segments - 1) {
                    cutList = data.subList(count * i, size);
                } else {
                    cutList = data.subList(count * i, count * (i + 1));
                }
                result.add(cutList);
            }
        } else {
            result.add(data);
        }
        return result;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值