前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >spring boot+mybatis plus 批量插入数据的操作方法

spring boot+mybatis plus 批量插入数据的操作方法

作者头像
用户7353950
发布2022-06-23 15:33:24
1.5K0
发布2022-06-23 15:33:24
举报
文章被收录于专栏:IT技术订阅IT技术订阅

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

代码语言:javascript
复制
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中提供了

代码语言:javascript
复制
/**
    * <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,泛型为被操作实体类

代码语言:javascript
复制
@Service
public  interface  WorkIService extends IService<CmpWork> {
 
}

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

代码语言:javascript
复制
@Service
public class WorkIServiceImpl extends ServiceImpl<WorkMapper, CmpWork> implements WorkIService{
}

其中WorkMapper为正常操作的mapper

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

代码语言:javascript
复制
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条数据级别内,差别不大,批量操作的优势可能大数据环境下才能显现吧。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-05-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 IT技术订阅 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档