好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

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

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

?

1

2

3

4

5

6

7

8

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

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

/**

     * <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 ,泛型为被操作实体类

?

1

2

3

4

@Service

public   interface   WorkIService extends IService<CmpWork> {

 

}

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

?

1

2

3

@Service

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

}

其中 WorkMapper 为正常操作的mapper

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

?

1

2

3

4

5

6

7

8

9

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 批量插入内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

原文链接:https://blog.csdn.net/leisure_life/article/details/98976565

查看更多关于MyBatis-Plus 批量插入数据的操作方法的详细内容...

  阅读:26次