MyBatisPlus 批量添加
创始人
2024-05-28 14:42:47
0

文章目录

  • 现状
  • 优化
  • 效果

现状

一般来说,批量插入可以使用 MyBatisPlus 中 ServiceImpl 自带的方法 saveBatch

在这里插入图片描述
打开 sql 日志,application.yml 添加配置,mapper-locations 配置 mapper 路径

mybatis-plus:configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #开启sql日志mapper-locations: classpath*:mapper/**/*Mapper.xml

可以发现插入是在同一个 SqlSession,但并不是理想中的批量插入
在这里插入图片描述

它的插入算法我没有细究,但从日志观察可以看出它的插入条数是无序的,如果可以一次插入全部,效率应该更高
 

优化

MyBatisPlus 预留了 insertBatchSomeColumn 方法,可以实现批量插入,下面介绍一下如何配置

  1. MyBatisPlus 依赖
com.baomidoumybatis-plus-boot-starter3.5.2

  1. 新建 Sql 注射器 BatchSqlInjector
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.core.injector.AbstractMethod;
import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector;
import com.baomidou.mybatisplus.core.metadata.TableInfo;
import com.baomidou.mybatisplus.extension.injector.methods.InsertBatchSomeColumn;
import java.util.List;public class BatchSqlInjector extends DefaultSqlInjector {@Overridepublic List getMethodList(Class mapperClass, TableInfo tableInfo) {List methodList = super.getMethodList(mapperClass, tableInfo);methodList.add(new InsertBatchSomeColumn(i -> i.getFieldFill() != FieldFill.UPDATE));return methodList;}}
  1. MybatisPlusConfig 配置 BatchSqlInjector Bean,可忽略这里配置的分页插件
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.BlockAttackInnerInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {/*** 分页插件** @return*/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new BlockAttackInnerInterceptor());PaginationInnerInterceptor pageInterceptor = new PaginationInnerInterceptor(DbType.MYSQL);pageInterceptor.setMaxLimit(500L);pageInterceptor.setOptimizeJoin(true);interceptor.addInnerInterceptor(pageInterceptor);return interceptor;}/*** 批量插入** @return*/@Beanpublic BatchSqlInjector easySqlInjector() {return new BatchSqlInjector();}
}
  1. 配置 BatchBaseMapper 继承 BaseMapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import java.util.Collection;public interface BatchBaseMapper extends BaseMapper {/*** 批量插入 仅适用于mysql** @param entityList 实体列表* @return 影响行数*/Integer insertBatchSomeColumn(Collection entityList);
}
  1. 业务 Mapper 继承 BatchBaseMapper
@Repository
public interface ISapCustomerMapper extends BatchBaseMapper {}
  1. service 创建 createBatch 作为新的批量插入方法
public class SapCustomerServiceImpl extends ServiceImpl {void createBatch(List entityList) {if(!entityList.isEmpty()){baseMapper.insertBatchSomeColumn(entityList);}}}

注意:不建议直接用 mapper 的 insertBatchSomeColumn 方法,因为当 entityList 为空时会报错
其实就是 INSERT INTO 表名(字段1,字段2,字段3) VALUES 后面为空

NestedRuntimeException:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ‘’ at line 1

 

效果

3600 条数据
优化前:2058 毫秒
优化后:1293 毫秒

15000 条数据
优化前:8958 毫秒
优化后:2037 毫秒

可以看出,数据越多,优化效果越明细

通过这次测试发现,打开 sql 日志后,会明细拖慢 sql 执行效率,数据越多越明细

相关内容

热门资讯

破13亿元!乌海海关上半年出境... 转自:草原云7月17日,记者从乌海海关了解到,今年上半年,乌海海关共受理出境货物出境检验检疫申请24...
播恩集团A股股东户数减少286... 7月16日消息,数据显示,截至2025年7月10日,播恩集团A股股东总户数为1.11万户,较上期(2...
英派斯股价跌5.04%,华夏基... 7月17日,英派斯跌5.04%,截至发稿,报23.16元/股,成交1.99亿元,换手率5.71%,总...
投资实现快速增长 设备购置引领... 一、设备购置投资延续良好增势上半年,全市设备购置投资同比增长99%,占全市投资比重为28.2%,同比...
综N代到了“不变就被观众无情抛... 文 | 犀牛娱乐 方正编辑 | 朴芳2025综N代正面临一个危局。这倒不是我们危言耸听,主要因为最近...
现场直击|新停火协议达成 叙国... 01:19叙利亚媒体和目击者16日说,以色列当天对叙“总统府”附近地区和叙“总参谋部”大楼等地发动空...
我在抗战旧址参与“修复”历史 转自:最高人民检察院今年是中国人民抗日战争暨世界反法西斯战争胜利80周年。为进一步铭记抗战历史、赓续...
联创电子涨2.04%,成交额2... 7月17日,联创电子盘中上涨2.04%,截至13:38,报10.98元/股,成交2.94亿元,换手率...
董秘说|纳睿雷达董秘龚雪华:A...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会!   由Hehson财...
中国AI修图赛道商业化前景凸显 转自:新华财经新华财经上海7月17日电(记者高少华)随着数字化浪潮席卷世界,AI技术飞速迭代,全球创...