MyBatis 分批次执行(新增,修改,删除)

import com.google.common.collect.Lists;import java.util.Iterator;
import java.util.List;
import java.util.function.Consumer;/*** @Description mybatis分批插入数据使用* @Author WangKun* @Date 2024/9/19 11:20* @Version*/
public class MyBatisSqlUtils {/*** @param data      全量数据(全部数据)* @param batchSize 批次插入大小(每次插入数据多少)* @param consumer  插入处理(插入值)* @Description 分批次批量插入* @Throws* @Return void* @Date 2024-09-19 11:22:05* @Author WangKun**/public static <E> void batch(List<E> data, int batchSize, Consumer<List<E>> consumer) {if (data == null || data.isEmpty()) {return;}List<E> list = Lists.newArrayList();int size = data.size();int mathMin = Math.min(batchSize, size);int i = 1;for (Iterator<E> item = data.iterator(); item.hasNext(); ++i) {list.add(item.next());if (i == mathMin) {consumer.accept(list);list.clear();mathMin = Math.min(mathMin + batchSize, size);}}}}

使用:以新增为例,每次插入100条

MyBatisSqlUtils.batch(list, 100, xxx-> {xxxService.insert (xxx);});//lambda写法调用
MyBatisSqlUtils.batch(list, 100, xxxService::insert);

xml中使用<foreach> 既可以了

例子

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/54356.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

4G 网络下资源加载失败?一次运营商封禁 IP 的案例分享

在工作中&#xff0c;网络问题是不可避免的挑战之一。最近&#xff0c;我们在项目中遇到了一起网络资源加载异常的问题&#xff1a;某同事在使用 4G 网络连接公司 VPN 时&#xff0c;云服务的前端资源居然无法加载&#xff01;通过一系列的排查和分析&#xff0c;我们发现问题的…

SQL案例分析:计算延迟法定退休年龄

2024年9月13日第十四届全国人民代表大会常务委员会第十一次会议通过了《关于实施渐进式延迟法定退休年龄的决定》。 从2025年1月1日起&#xff0c;男职工和原法定退休年龄为五十五周岁的女职工&#xff0c;法定退休年龄每四个月延迟一个月&#xff0c;分别逐步延迟至六十三周岁…

DataFrame生成excel后为什么多了一行数字

问题描述 python查询数据生成excel文件&#xff0c;生成的excel多了第一行数字索引&#xff0c;1,2,3,4,5...... 代码&#xff1a; df pd.DataFrame(data)df.to_excel(filename, sheet_name用户信息表, indexFalse) 解决&#xff1a; 原理也很简单&#xff0c;就是设置个参…

Shell脚本弹奏中文版“生日快乐歌”

在《Shell命令控制蜂鸣器发声》一文中&#xff0c;我们了解到了如何在Ubuntu下安装beep命令来控制PC主板上蜂鸣器发声&#xff0c;这次我们想让蜂鸣器弹奏出中文版的“生日快乐歌”&#xff0c;首先还是要用sudo modprobe pcspkr命令加载驱动&#xff0c;然后在Shell脚本所在目…

深入浅出通信原理

深入浅出通信原理 文章目录 深入浅出通信原理前言一、概述二、信号和频谱2.1 信号2.2 信号的分解与合成2.3 傅里叶变换的特性2.4 离散傅里叶变化 三 信道3.1 衰减和损耗3.2 多普勒效应 四 信源编码4.1 采样4.2 量化4.3 编码 五 基带信号的发送和接受5.1 脉冲成形5.2 眼图 六 频…

我的demo保卫萝卜中的技术要点

管理类&#xff1a; GameManager&#xff08;单例&#xff09;&#xff0c;GameController(单例)&#xff1b; 一些其他的管理类&#xff08;PlayerManager,AudioSourceManager,FactoryManager&#xff09;作为GameManager的成员变量存在&#xff08;这样也可以保证只有一个存…

高德地图JS API AMap.MouseTool绘制

fang &#x1f916; 作者简介&#xff1a;水煮白菜王 &#xff0c;一位资深前端劝退师 &#x1f47b; &#x1f440; 文章专栏&#xff1a; 高德AMap专栏 &#xff0c;记录一下平时在博客写作中&#xff0c;总结出的一些开发技巧✍。 感谢支持&#x1f495;&#x1f495;&#…

24.9.2-24.9.20第一次周总结

小升初了&#xff0c;以后每周发一次周总结。 语文 1. 写完了写字本 2. 预习完了语文课本 作文积累&#xff1a; 丁香结课文可写所有题目&#xff0c;写景写人写物都可以套用。 写景是为了抒情&#xff0c;没有纯写景的作文。 数学 《奥数》做到了第三周第四页&#xf…

本地搭建我的世界服务器(JAVA)简单记录

网上参考教程挺多的&#xff0c;踩了不少坑&#xff0c;简单记录一下&#xff0c;我做的是一个私人服务器&#xff0c;就是和朋友3、4个人玩。 笨蛋 MC 开服教程 先放一个比较系统和完整的教程&#xff0c;萌新可用&#xff0c;这个教程很详细&#xff0c;我只是记录一下自己的…

【QT】定时器使用

文章目录 关于 Qt 定时器使用的注意细节总结实例-检查工具使用周期时间是否合理UI设计头文件 remind.h源文件 remind.cpp实现效果 关于 Qt 定时器使用的注意细节总结 一、创建与初始化 使用 QTimer 类来创建定时器。可以在构造函数中指定父对象&#xff0c;确保定时器在正确的…

自动化测试常用函数

目录 一、元素的定位 1、cssSelector 2、xpath &#xff08;1&#xff09;xpath 语法 1、获取HTML页面所有的节点 2、获取HTML页面指定的节点 3、获取一个节点中的直接子节点 4、获取一个节点的父节点 5、实现节点属性的匹配 6、使用指定索引的方式获取对应的节点内容…

python中装饰器的作用

在Python中&#xff0c;装饰器&#xff08;Decorator&#xff09;是一种强大的工具&#xff0c;它允许你在不修改原有函数代码的情况下&#xff0c;给函数增加新的功能。装饰器本质上是一个函数&#xff0c;它接受一个函数作为参数并返回一个新的函数&#xff0c;这个新函数通常…

【鸿蒙】HarmonyOS NEXT星河入门到实战8-自定义组件-组件通信

目录 1、模块化语法 1.1 模块化基本认知 1.2 默认导出和导入 1.2.1 在ets下新建tools目录 1.2.2 在tools下新建moduls.ets文件 1.2.3 index.ets 1.3 按需导出和导入 1.4 全部导入 2、自定义组件 -基础 2.1 自定义组件 - 基本使用 2.2 自定义组件 -通用样式 2.2.1 et…

OceanBase中Range 分区 和 Range Columns 分区

1. Range 分区和 Range Columns 分区的区别 Range 分区&#xff1a;只允许基于一个整型列&#xff08;INT 类型&#xff09;的值范围进行分区。通常适用于那些可以自然用整数来表达的值&#xff0c;如商品编号、用户 ID 等。OceanBase 限定 Range 分区的分区键为 INT 类型&…

大数据Flink(一百二十二):阿里云Flink MySQL连接器介绍

文章目录 阿里云Flink MySQL连接器介绍 一、特色功能 二、​​​​​​​语法结构 三、​​​​​​​​​​​​​​WITH参数 阿里云Flink MySQL连接器介绍 阿里云提供了MySQL连接器&#xff0c;其作为源表时&#xff0c;扮演的就是flink cdc的角色。 一、特色功能 MySQ…

neo4j导入csv数据

neo4j数据可视化实践 手动输入数据 - 官方democsv数据导入准备数据数据处理导入步骤① 导入疾病表格② 导入药物表格③导入疾病-药物关系表格 爬虫的csv文件 手动输入数据 - 官方demo 点击之后&#xff0c;按照左边10张图中的代码&#xff0c;复制粘贴熟悉语法 效果如下 csv数据…

基于JAVA+SpringBoot+Vue的学生干部管理系统

基于JAVASpringBootVue的学生干部管理系统 前言 ✌全网粉丝20W,csdn特邀作者、博客专家、CSDN[新星计划]导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末附源码下载链接&#x1f345; 哈…

【AI视频】Runway:Gen-2 运镜详解

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AI视频 | Runway 文章目录 &#x1f4af;前言&#x1f4af;Camera Control&#xff08;运镜&#xff09;&#x1f4af;Camera Control功能测试Horizonta&#xff08;左右平移&#xff09;Vertical&#xff08;上下平移&#xff0…

UNION嵌套STRUCT的两种类型

1. STRUCT里面的总长度大于UNION中的最大长度 在UNION类型中&#xff0c;嵌套如STRUCT类型&#xff0c;其中STRUCT的类型还比UNION类型中最大的类型的长度还长的时候&#xff0c;会如何处理呢&#xff0c;看下面示例 程序源码 #include "stdafx.h"typedef unsigned…

滚雪球学SpringCloud[5.2讲]: 配置的动态刷新与安全管理

全文目录&#xff1a; 前言5.2 配置的动态刷新与安全管理使用Spring Cloud Bus实现动态刷新动态刷新在多种场景中的应用Spring Cloud Bus的工作机制与架构分析核心架构&#xff1a; 示例&#xff1a;Spring Cloud Bus动态刷新配置1. 引入依赖2. 配置RabbitMQ3. 启用Bus功能4. 触…