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 相关文章推荐
Java输出Hello World完美过程解析
Jun 13 Java/Android
解决tk mapper 通用mapper的bug问题
Jun 16 Java/Android
SpringBoot实现异步事件驱动的方法
Jun 28 Java/Android
JavaGUI模仿QQ聊天功能完整版
Jul 04 Java/Android
Java中CyclicBarrier和CountDownLatch的用法与区别
Aug 23 Java/Android
解析mybatis-plus中的resultMap简单使用
Nov 23 Java/Android
Java并发编程之原子性-Atomic的使用
Mar 16 Java/Android
spring注解 @PropertySource配置数据源全流程
Mar 25 Java/Android
Android基于Fresco实现圆角和圆形图片
Apr 01 Java/Android
Java中API的使用方法详情
Apr 06 Java/Android
SpringBoot 集成短信和邮件 以阿里云短信服务为例
Apr 22 Java/Android
SpringCloud中分析讲解Feign组件添加请求头有哪些坑梳理
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
法国:浪漫之都的咖啡文化
2021/03/03 咖啡文化
7个超级实用的PHP代码片段
2011/07/11 PHP
PHP中几个常用的魔术常量
2012/02/23 PHP
Javascript 不能释放内存.
2006/09/07 Javascript
js表格分页实现代码
2009/09/18 Javascript
JavaScript 面向对象编程(1) 基础
2010/05/18 Javascript
extjs grid设置某列背景颜色和字体颜色的实现方法
2010/09/06 Javascript
解析JavaScript中instanceof对于不同的构造器或许都返回true
2013/12/03 Javascript
js四舍五入数学函数round使用实例
2014/05/09 Javascript
js实现点击添加一个input节点
2014/12/05 Javascript
JavaScript的RequireJS库入门指南
2015/07/01 Javascript
javascript+html5实现绘制圆环的方法
2015/07/28 Javascript
深入浅析JavaScript中对事件的三种监听方式
2015/09/29 Javascript
使用jquery插件qrcode生成二维码
2015/10/22 Javascript
jQuery EasyUi实战教程之布局篇
2016/01/26 Javascript
JS实现兼容各种浏览器的高级拖动方法完整实例【测试可用】
2016/06/21 Javascript
KnockoutJS 3.X API 第四章之表单textInput、hasFocus、checked绑定
2016/10/11 Javascript
关于vue.js过渡css类名的理解(推荐)
2017/04/10 Javascript
nodejs中解决异步嵌套循环和循环嵌套异步的问题
2017/07/12 NodeJs
JS计算输出100元钱买100只鸡问题的解决方法
2018/01/04 Javascript
浅谈vue项目打包优化策略
2018/09/29 Javascript
微信小程序自定义tabBar组件开发详解
2020/09/24 Javascript
JS实现的A*寻路算法详解
2018/12/14 Javascript
解决layer图标icon不加载的问题
2019/09/04 Javascript
[01:20]DOTA2 2017国际邀请赛冠军之路无止竞
2017/06/19 DOTA
python类继承用法实例分析
2014/10/10 Python
python 循环while和for in简单实例
2016/08/16 Python
Python编程对列表中字典元素进行排序的方法详解
2017/05/26 Python
PyTorch的深度学习入门教程之构建神经网络
2019/06/27 Python
Python安装与卸载流程详细步骤(图解)
2020/02/20 Python
Python解释器及PyCharm工具安装过程
2020/02/26 Python
生物专业个人自荐信范文
2013/11/29 职场文书
售前工程师职业生涯规划
2014/03/02 职场文书
法定代表人授权委托书格式
2014/10/14 职场文书
六年级语文教学反思
2016/03/03 职场文书
解析CSS 提取图片主题色功能(小技巧)
2021/05/12 HTML / CSS