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 相关文章推荐
SpringCloud Alibaba 基本开发框架搭建过程
Jun 13 Java/Android
springboot如何初始化执行sql语句
Jun 22 Java/Android
Spring Cloud Gateway去掉url前缀
Jul 15 Java/Android
springboot如何接收application/x-www-form-urlencoded类型的请求
Nov 02 Java/Android
JavaCV实现照片马赛克效果
Jan 22 Java/Android
解析探秘fescar分布式事务实现原理
Feb 28 Java/Android
Mybatis-Plus进阶分页与乐观锁插件及通用枚举和多数据源详解
Mar 21 Java/Android
Java 数据结构七大排序使用分析
Apr 02 Java/Android
Spring Data JPA框架Repository自定义实现
Apr 28 Java/Android
Java 数组的使用
May 11 Java/Android
Java 中的 Lambda List 转 Map 的多种方法详解
Jul 07 Java/Android
Java使用HttpClient实现文件下载
Aug 14 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实现首页链接查询 友情链接检查的代码
2010/01/05 PHP
PHP5常用函数列表(分享)
2013/06/07 PHP
解析PHP获取当前网址及域名的实现代码
2013/06/23 PHP
php计算函数执行时间的方法
2015/03/20 PHP
PHP用mysql_insert_id()函数获得刚插入数据或当前发布文章的ID
2016/11/25 PHP
JS实现slide文字框缩放伸展效果代码
2015/11/05 Javascript
Bootstrap学习笔记之css样式设计(1)
2016/06/07 Javascript
JavaScript导航脚本判断当前导航
2016/07/12 Javascript
nodejs微信公众号支付开发
2016/09/19 NodeJs
浅谈JavaScript的闭包函数
2016/12/08 Javascript
浅谈jQuery操作类数组的工具方法
2016/12/23 Javascript
underscore之function_动力节点Java学院整理
2017/07/11 Javascript
vue.js template模板的使用(仿饿了么布局)
2018/08/13 Javascript
vue2.0 + ele的循环表单及验证字段方法
2018/09/18 Javascript
原生js实现可兼容PC和移动端的拖动滑块功能详解【测试可用】
2019/08/15 Javascript
解决LayUI数据表格复选框不居中显示的问题
2019/09/25 Javascript
详解Vue中Axios封装API接口的思路及方法
2020/10/10 Javascript
由Python运算π的值深入Python中科学计算的实现
2015/04/17 Python
python对配置文件.ini进行增删改查操作的方法示例
2017/07/28 Python
浅谈Django自定义模板标签template_tags的用处
2017/12/20 Python
Python实现判断给定列表是否有重复元素的方法
2018/04/11 Python
浅谈python编译pyc工程--导包问题解决
2019/03/20 Python
pandas的to_datetime时间转换使用及学习心得
2019/08/11 Python
Python异常模块traceback用法实例分析
2019/10/22 Python
TensorFlow 多元函数的极值实例
2020/02/10 Python
pytorch masked_fill报错的解决
2020/02/18 Python
Python类及获取对象属性方法解析
2020/06/15 Python
Pycharm 跳转回之前所在页面的操作
2021/02/05 Python
Html5自定义字体解决方法
2019/10/09 HTML / CSS
Html5页面点击遮罩层背景关闭遮罩层
2020/11/30 HTML / CSS
马来西亚在线药房:RoyalePharma
2019/12/01 全球购物
物业保安员岗位职责
2014/03/14 职场文书
授权委托书样本
2014/04/03 职场文书
汽车维修求职信
2014/06/15 职场文书
公共艺术专业自荐信
2014/09/01 职场文书
暑假社会实践证明格式
2014/10/28 职场文书