替换 MyBatis-Plus 默认的 saveBatch的实现步骤

 更新时间:2026年03月30日 09:14:31   作者:mtdxns  
本文主要介绍了替换 MyBatis-Plus 默认的 saveBatch的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

MyBatis-Plus 默认的 saveBatch 并不是真正意义上的“批量 SQL”,而是循环调用单条 INSERT,仅在 JDBC 层启用了 BATCH 模式。若数据库驱动未开启特定参数(如 MySQL 的 rewriteBatchedStatements=true),底层仍会逐条发送 SQL,导致大量网络往返和数据库解析开销。

实现步骤:

Mapper 接口

public interface YourMapper extends BaseMapper<YourModel> {
    void insertBatch(@Param("list") List<YourModel> list);
}

XML 文件(放在 resources/mapper/ 下)

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.yourpackage.YourMapper">
    <insert id="insertBatch">
        INSERT INTO your_table_name (
            id,
            name,
            create_time
            <!-- 列出所有字段 -->
        ) VALUES
        <foreach collection="list" item="item" separator=",">
            (
                #{item.id},
                #{item.name},
                #{item.createTime}
                <!-- 对应字段值 -->
            )
        </foreach>
    </insert>
</mapper>

通用批量执行工具(基于函数式接口)

创建工具类BatchUtil.java

import org.springframework.stereotype.Component;
import java.util.List;
import java.util.function.Consumer;
@Component
public class BatchUtil {
    /**
     * 通用分批执行方法
     *
     * @param dataList    要处理的数据列表
     * @param batchSize   每批大小
     * @param batchAction 每批数据的处理逻辑(例如:mapper::insertBatch)
     * @param <T>         数据类型
     */
    public <T> void executeBatch(List<T> dataList, int batchSize, Consumer<List<T>> batchAction) {
        if (dataList == null || dataList.isEmpty()) {
            return;
        }
        for (int i = 0; i < dataList.size(); i += batchSize) {
            int end = Math.min(i + batchSize, dataList.size());
            batchAction.accept(dataList.subList(i, end));
        }
    }
}

在 Service 中使用(示例)

@Autowired
private BatchUtil batchUtil;
batchUtil.executeBatch(list, 500, YourMapper::insertBatch);

配合 @Transactional 使用

到此这篇关于替换 MyBatis-Plus 默认的 saveBatch的实现步骤的文章就介绍到这了,更多相关替换MyBatis-Plus saveBatch内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java解析json数组方式

    java解析json数组方式

    这篇文章主要介绍了java解析json数组方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • Java数据结构专题解析之栈和队列的实现

    Java数据结构专题解析之栈和队列的实现

    从数据结构的定义看,栈和队列也是一种线性表。其不同之处在于栈和队列的相关运算具有特殊性,只是线性表相关运算的一个子集。更准确的说,一般线性表的插入、删除运算不受限制,而栈和队列上的插入删除运算均受某种特殊限制。因此,栈和队列也称作操作受限的线性表
    2021-10-10
  • 详解Spring DeferredResult异步操作使用场景

    详解Spring DeferredResult异步操作使用场景

    本文主要介绍了Spring DeferredResult异步操作使用场景,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 使用mybatis-plus报错Invalid bound statement (not found)错误

    使用mybatis-plus报错Invalid bound statement (not found)错误

    这篇文章主要介绍了使用mybatis-plus报错Invalid bound statement (not found)错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • SpringBoot 整合WebSocket 前端 uniapp 访问的详细方法

    SpringBoot 整合WebSocket 前端 uniapp 访问的详细方法

    这篇文章主要介绍了SpringBoot 整合WebSocket 前端 uniapp 访问的详细方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • springboot 配置DRUID数据源的方法实例分析

    springboot 配置DRUID数据源的方法实例分析

    这篇文章主要介绍了springboot 配置DRUID数据源的方法,结合实例形式分析了springboot 配置阿里DRUID数据源的具体步骤与相关操作技巧,需要的朋友可以参考下
    2019-12-12
  • idea向System.getenv()添加系统环境变量的操作

    idea向System.getenv()添加系统环境变量的操作

    这篇文章主要介绍了idea向System.getenv()添加系统环境变量的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • spring实现动态切换、添加数据源及源码分析

    spring实现动态切换、添加数据源及源码分析

    这篇文章主要给大家介绍了关于spring实现动态切换、添加数据源及源码分析的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-09-09
  • 使用@Autowired注解有错误提示的解决

    使用@Autowired注解有错误提示的解决

    这篇文章主要介绍了使用@Autowired注解有错误提示的解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • SpringBoot+WebSocket实现消息推送功能

    SpringBoot+WebSocket实现消息推送功能

    WebSocket协议是基于TCP的一种新的网络协议。本文将通过SpringBoot集成WebSocket实现消息推送功能,感兴趣的可以了解一下
    2022-08-08

最新评论