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中重写父类方法加不加@Override详解
Jun 21 Java/Android
探讨Java中的深浅拷贝问题
Jun 26 Java/Android
Java比较两个对象中全部属性值是否相等的方法
Aug 07 Java/Android
Spring Security中用JWT退出登录时遇到的坑
Oct 16 Java/Android
Java中API的使用方法详情
Apr 06 Java/Android
Java字符缓冲流BufferedWriter
Apr 09 Java/Android
Android自定义双向滑动控件
Apr 19 Java/Android
Flutter Navigator 实现路由传递参数
Apr 22 Java/Android
JAVA 线程池(池化技术)的实现原理
Apr 28 Java/Android
Java时间工具类Date的常用处理方法
May 25 Java/Android
Android中View.post和Handler.post的关系
Jun 05 Java/Android
详解Spring Bean的配置方式与实例化
Jun 10 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
自动把纯文本转换成Web页面的php代码
2009/08/27 PHP
php UBB 解析实现代码
2011/11/27 PHP
php连接mssql数据库的几种方法
2013/02/21 PHP
浅谈PHP解析URL函数parse_url和parse_str
2014/11/11 PHP
PHP面向对象程序设计重载(overloading)操作详解
2019/06/13 PHP
jquery 插件实现图片延迟加载效果代码
2010/02/06 Javascript
js的写法基础分析
2011/01/17 Javascript
javascript日期转换 时间戳转日期格式
2011/11/05 Javascript
jQuery EasyUI API 中文文档 - Tree树使用介绍
2011/11/19 Javascript
js加载读取内容及显示与隐藏div示例
2014/02/13 Javascript
JavaScript实现点击文字切换登录窗口的方法
2015/05/11 Javascript
js正则匹配出所有图片及图片地址src的方法
2015/06/08 Javascript
bootstrap-treeview自定义双击事件实现方法
2016/01/09 Javascript
Jquery和angularjs获取check框选中的值的方法汇总
2016/01/17 Javascript
JavaScript操作选择对象的简单实例
2016/05/16 Javascript
js前端日历控件(悬浮、拖拽、自由变形)
2017/03/02 Javascript
JS库之Highlight.js的用法详解
2017/09/13 Javascript
9种使用Chrome Firefox 自带调试工具调试javascript技巧
2017/12/22 Javascript
关于vue中的ajax请求和axios包问题
2018/04/19 Javascript
JS实现点击按钮可实现编辑功能
2018/07/03 Javascript
vue forEach循环数组拿到自己想要的数据方法
2018/09/21 Javascript
微信小程序实现左侧滑栏过程解析
2019/08/26 Javascript
vue项目中使用rem,在入口文件添加内容操作
2020/11/11 Javascript
Python将图片批量从png格式转换至WebP格式
2020/08/22 Python
对django views中 request, response的常用操作详解
2019/07/17 Python
django框架使用方法详解
2019/07/18 Python
python3使用GUI统计代码量
2019/09/18 Python
Pytorch使用MNIST数据集实现基础GAN和DCGAN详解
2020/01/10 Python
解决python 虚拟环境删除包无法加载的问题
2020/07/13 Python
德国机车企业:FC-Moto
2017/10/27 全球购物
墨尔本复古时尚品牌:Dangerfield
2018/12/12 全球购物
幼师岗位求职简历的自荐信格式
2013/09/21 职场文书
房屋租赁委托书范本
2014/10/04 职场文书
召开会议通知范文
2015/04/15 职场文书
Redis安装启动及常见数据类型
2021/04/14 Redis
Nginx配置https的实现
2021/11/27 Servers