MyBatis-Plus 批量插入数据的操作方法


Posted in Java/Android onSeptember 25, 2021

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中提供了

/**
     * <p>
     * 插入(批量),该方法不适合 Oracle
     * </p>
     *
     * @param entityList 实体对象列表
     * @return boolean
     */
    boolean insertBatch(List<T> entityList);

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

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

@Service
public  interface  WorkIService extends IService<CmpWork> {

}

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

@Service
public class WorkIServiceImpl extends ServiceImpl<WorkMapper, CmpWork> implements WorkIService{
}

其中WorkMapper为正常操作的mapper

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

List<CmpWork> 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条数据级别内,差别不大,批量操作的优势可能大数据环境下才能显现吧

到此这篇关于MyBatis-Plus 批量插入的文章就介绍到这了,更多相关MyBatis-Plus 批量插入内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Java/Android 相关文章推荐
jackson json序列化实现首字母大写,第二个字母需小写
Jun 29 Java/Android
SpringBoot快速入门详解
Jul 21 Java/Android
SpringBoot实现quartz定时任务可视化管理功能
Aug 30 Java/Android
详解Java七大阻塞队列之SynchronousQueue
Sep 04 Java/Android
springboot新建项目pom.xml文件第一行报错的解决
Jan 18 Java/Android
JVM的类加载器和双亲委派模式你了解吗
Mar 13 Java/Android
Java中的随机数Random
Mar 17 Java/Android
Java 使用类型为Object的变量指向任意类型的对象
Apr 13 Java/Android
Java 写一个简单的图书管理系统
Apr 26 Java/Android
Spring Boot 实现 WebSocket
Apr 30 Java/Android
openGauss数据库JDBC环境连接配置的详细过程(Eclipse)
Jun 01 Java/Android
Mybatis-plus配置分页插件返回统一结果集
Jun 21 Java/Android
spring cloud 配置中心native配置方式
Sep 25 #Java/Android
spring cloud 配置中心客户端启动遇到的问题
Sep 25 #Java/Android
SpringBoot+Vue+JWT的前后端分离登录认证详细步骤
Sep 25 #Java/Android
java如何实现socket连接方法封装
Sep 25 #Java/Android
IDEA2021.2配置docker如何将springboot项目打成镜像一键发布部署
Java数据开发辅助工具Docker与普通程序使用方法
Sep 15 #Java/Android
使用springMVC所需要的pom配置
Sep 15 #Java/Android
You might like
PHP网页游戏学习之Xnova(ogame)源码解读(二)
2014/06/23 PHP
采用memcache在web集群中实现session的同步会话
2014/07/05 PHP
PHP的PDO预处理语句与存储过程
2019/01/27 PHP
如何利用PHP实现上传图片功能详解
2020/09/24 PHP
javascript 动态加载 css 方法总结
2009/07/11 Javascript
Jquery实现仿新浪微博获取文本框能输入的字数代码
2013/02/22 Javascript
jQuery方法简洁实现隔行换色及toggleClass的使用
2013/03/15 Javascript
json数据处理技巧(字段带空格、增加字段、排序等等)
2013/06/14 Javascript
javascript创建createXmlHttpRequest对象示例代码
2014/02/10 Javascript
js charAt的使用示例
2014/02/18 Javascript
浅谈JavaScript中setInterval和setTimeout的使用问题
2015/08/01 Javascript
跟我学习javascript的循环
2015/11/18 Javascript
JQUERY表单暂存功能插件分享
2016/02/23 Javascript
JS代码实现table数据分页效果
2016/05/26 Javascript
详解Vue 事件驱动和依赖追踪
2017/04/22 Javascript
基于Cookie常用操作以及属性介绍
2017/09/07 Javascript
vue v-model实现自定义样式多选与单选功能
2018/07/05 Javascript
JavaScript解析机制与闭包原理实例详解
2019/03/08 Javascript
JS实现拖拽元素时与另一元素碰撞检测
2020/08/27 Javascript
[48:39]Ti4主赛事胜者组第一天 EG vs NEWBEE 2
2014/07/19 DOTA
python 默认参数问题的陷阱
2016/02/29 Python
Python数据结构与算法之图的基本实现及迭代器实例详解
2017/12/12 Python
教你用Python创建微信聊天机器人
2020/03/31 Python
Python内置函数reversed()用法分析
2018/03/20 Python
利用python打开摄像头及颜色检测方法
2018/08/03 Python
Django分页功能的实现代码详解
2019/07/29 Python
TensorFlow dataset.shuffle、batch、repeat的使用详解
2020/01/21 Python
Moss Bros官网:英国排名第一的西装店
2020/02/26 全球购物
Ibatis的核心配置文件都有什么
2014/09/08 面试题
人力资源管理毕业生自荐信
2013/11/21 职场文书
森林防火工作方案
2014/02/14 职场文书
检讨书范文1000字
2015/01/28 职场文书
公司开业主持词
2015/07/02 职场文书
消防安全培训工作总结
2015/10/23 职场文书
幼儿园托班开学寄语(2016春季)
2015/12/03 职场文书
世界无敌的ICOM IC-R9500宽频接收机
2022/03/25 无线电