当前位置: 首页 > news >正文

mybatis批量插入

一、定义DBExec

import java.util.List;public abstract class DBExec<T> {public abstract void operate(List<T> list);
}

二、定义BatchDBService

public interface BatchDBService<T> {void exec(int batchSize, List<T> list, DBExec<T> dbExec);
}

三、实现BatchDBService

@Service
public class BatchDBImpl<T> implements BatchDBService<T> {@Overridepublic void exec(int batchSize, List<T> list, DBExec<T> dbExec) {if (list != null && list.size() > 0) {int init = batchSize;// 每隔batchSize条循环一次int total = list.size();int cycelTotal = total / init;//获取循环次数if (total % init != 0) {cycelTotal += 1;if (total < init) {init = total;}}for (int j = 0; j < cycelTotal; j++) {List<T> batchInsertList = new ArrayList<>();for (int i = j * init; i < (j + 1) * init && i < list.size(); i++) {batchInsertList.add(list.get(i));}dbExec.operate(batchInsertList);}}}
}

四、使用

   BatchDBService batchDBService = new BatchDBImpl();DBExec<TestDO> saveDBExec = new DBExec<TestDO>() {@Overridepublic void operate(List<TestDO> list) {testDao.batchInsert(list);}};batchDBService.exec(2000, testList, saveDBExec);

http://www.lryc.cn/news/188359.html

相关文章:

  • 软件‘小程序‘前台开发软件定制的知识|app网站搭建
  • HTML-注册页面
  • 17.(开发工具篇Gitlab)如何在Gitlab配置ssh key
  • ArcGIS/GeoScene脚本:基于粒子群优化的支持向量机分类模型
  • Python+Tkinter 图形化界面基础篇:添加图形和图像
  • 前端js八股文大全
  • [环境]Ubuntu20.04安装Ceres
  • ruoyi 若依 前端vue npm install 运行vue前端
  • 各大搜索引擎的User-Agent
  • codesys【按钮】
  • SSH在桌面会话启动应用程序
  • React的类式组件和函数式组件之间有什么区别?
  • codesys【读写轴参数】
  • Java架构师系统架构设计确定系统边界
  • pytorch实现经典神经网络:VGG16模型之初探
  • Newtonsoft.Json use
  • MySQL-3(9000字详解)
  • SLAM从入门到精通(3d 点云数据访问)
  • 如何在 Spring Boot 中提高应用程序的安全性
  • 【Vuex+ElementUI】
  • 多媒体播放软件 Infuse mac中文特点介绍
  • 华为数通方向HCIP-DataCom H12-831题库(单选题:201-220)
  • 【管理运筹学】第 9 章 | 网络计划(2,时间参数的计算 —— 工作时间的确定与事项的时间参数)
  • 英语——方法篇——单词——羊肉串记忆法——单词密码
  • 【m98】视频帧的 jitterbuffer 1:
  • javascript中map和filter的区别与联系
  • 【RabbitMQ 实战】10 消息持久化和存储原理
  • vscode 连接ubuntu git下载缓慢
  • 2731. 移动机器人
  • 小程序实现人脸识别功能