MyBatis-Plus 批量插入

MyBatis-Plus 批量插入springboot mybatisplus 环境 单条插入用的是 BaseMapper 自带的 insert 方法 publicApiRes Ancanc ApiResultres newApiResult Integerinser ancMapper insert anc if

spring boot+mybatis plus环境,单条插入用的是BaseMapper自带的insert方法

public ApiResult addAnc(Anc anc) { ApiResult result = new ApiResult(); Integer insert = ancMapper.insert(anc); if (insert < 1) { return result.failed("发布失败,请联系管理员"); } return result.success(anc); 

BaseMapper未提供批量插入接口,但是在com.baomidou.mybatisplus.service.IService中提供了

 / * 

* 插入(批量),该方法不适合 Oracle *

* * @param entityList 实体对象列表 * @return boolean */ boolean insertBatch(List entityList); / *

* 插入(批量) *

* * @param entityList 实体对象列表 * @param batchSize 插入批次数量 * @return boolean */ boolean insertBatch(List entityList, int batchSize);

使用方法,定义一个自己的接口,继承IService,泛型为被操作实体类

 @Service public interface WorkIService extends IService 
  
    { } 
  

定义一个实现类,实现上诉接口

@Service public class WorkIServiceImpl extends ServiceImpl 
  
    implements WorkIService{ } 
  

其中WorkMapper为正常操作的mapper

在业务中测试批量插入操作

List 
  
    entityList = new ArrayList<>(1000); for (int i=1;i<10000;i++){ CmpWork work = new CmpWork(); work.setWorkName("workNametestBatch"+i); work.setWorkID("testBatch"+i); work.setCreTm(DateUtil.dateToYMDHMS(new Date())); entityList.add(work); } boolean b = workIService.insertBatch(entityList); 
  

和单条插入的执行对比了一下,在1000条数据级别内,差别不大

经探究,其实其内部实现用的就是for循环,搞了个寂寞~

@Transactional(rollbackFor = Exception.class) @Override public boolean insertBatch(List<T> entityList, int batchSize) { 
    if (CollectionUtils.isEmpty(entityList)) { 
    throw new IllegalArgumentException("Error: entityList must not be empty"); } try (SqlSession batchSqlSession = sqlSessionBatch()) { 
    int size = entityList.size(); String sqlStatement = sqlStatement(SqlMethod.INSERT_ONE); for (int i = 0; i < size; i++) { 
    batchSqlSession.insert(sqlStatement, entityList.get(i)); if (i >= 1 && i % batchSize == 0) { 
    batchSqlSession.flushStatements(); } } batchSqlSession.flushStatements(); } catch (Throwable e) { 
    throw new MybatisPlusException("Error: Cannot execute insertBatch Method. Cause", e); } return true; } 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/217680.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午9:01
下一篇 2026年3月18日 上午9:01


相关推荐

  • 2022最新ES面试题整理(Elasticsearch面试指南系列)「建议收藏」

    2022最新ES面试题整理(Elasticsearch面试指南系列)「建议收藏」Elasticsearch经典面试题:10/50

    2025年9月6日
    4
  • object.hashcode的作用_java的hashcode方法

    object.hashcode的作用_java的hashcode方法Java中的hashCode方法就是根据一定的规则将与对象相关的信息(比如对象的存储地址,对象的字段等)映射成一个数值,这个数值称作为散列值。其主要作用是为了配合基于散列的集合一起正常运行,这样的散列集合包括HashSet、HashMap以及HashTable。当集合要添加新的对象时,先调用这个对象的hashCode方法,得到对应的hashcode值,实际上在HashMap的具…

    2025年10月4日
    5
  • 定位技术分类

    定位技术分类室内定位技术采用的方法

    2026年3月18日
    1
  • Win10下用Anaconda安装TensorFlow

    Win10下用Anaconda安装TensorFlow笔者之前在学习TensorFlow,也在自己的笔记本上完成了安装,在PyCharm中进行学习。但是最近为了使用python的科学计算环境,我把之前的环境卸载了,并用Anaconda重新安装了TensorFlow,由于自己的笔记本已经很旧了,显卡不行,所以这里介绍一下cpu版本的安装方法和自己遇到的一些坑,截图甚多。

    2022年6月25日
    31
  • tabnine激活码【注册码】

    tabnine激活码【注册码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    54
  • 大数据经典案例有哪些?

    大数据经典案例有哪些?“互联网还没搞清楚的时候,移动互联就来了移动互联还没搞清楚的时候,大数据就来了”。近两年,“大数据”这个词越来越为大众所熟悉,“大数据”一直是以高冷的形象出现在大众面前,面对大数据,相信许多人都一头雾水。下面我们通过几个经典案例,让大家实打实触摸一把“大数据”。你会发现它其实就在身边而且也是很有趣的。1.啤酒与尿布全球零售业巨头沃尔玛在对消费者购物行为分析时发现,男性顾客在购买婴儿尿片时,常常会顺便搭配几瓶啤酒来犒劳自己,于是尝试推出了将啤酒和尿布摆在一起的促销手段。没想到这个举措居然使尿布

    2022年5月2日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号