数据入库条数限制解决

数据入库条数限制解决

postgresql对于sql语句的参数数量是有限制的,最大为32767。及行数*列数最大值为32767

通过subList()方法将集合中的数据进行分批插入

package com.xj.utils;

import com.xj.entity.commen.InsertBatch;
import org.springframework.web.multipart.MultipartFile;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @program:Java_trs
 * @description:批量插入数据
 * @author:尚龙龙
 * @create:2021-03-11-09:56
 **/
public class InsertBatchUtil {

    public <T> List<InsertBatch> subList(List<T> list) {
        Map map = new HashMap();
        List<InsertBatch> listArray = new ArrayList();
        int columnNum = list.get(0).getClass().getDeclaredFields().length;
        int numberBatch = columnNum * list.size(); //上传参数总数据量
        int result = 0;
        double number = numberBatch / 32767; //数据量拆分
        if (numberBatch%32767 == 0){
            number = number;
        }else{
            number = number+1;
        }
        int n = ((Double)Math.ceil(number)).intValue(); //向上取整
        for(int i = 0; i < n; i++){
            int end = list.size()/n;
            if (i == n-1){
                end = list.size() - end * i;
            }
            InsertBatch insertBatch = new InsertBatch();
            insertBatch.setBeginIndex(end*(i));
            insertBatch.setEndIndex(end*(i+1));
            listArray.add(insertBatch);
        }
        return listArray;
    }
}

Service层
调用进行分批插入操作

    @Override
    public int insert(List<WkKbusiness> wkKbusiness){
        int result = 0;
        InsertBatchUtil insertBatchUtil = new InsertBatchUtil();
        List<InsertBatch> list = insertBatchUtil.subList(wkKbusiness);
        for (InsertBatch insertBatch:list){
            result = wkKbusinessMapper.insert(wkKbusiness.subList(insertBatch.getBeginIndex(), insertBatch.getEndIndex())); //插入数据库
        }
        return result;
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值