溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Mybatis-Plus如何實(shí)現(xiàn)批量插入

發(fā)布時(shí)間:2021-09-26 10:03:51 來源:億速云 閱讀:733 作者:小新 欄目:開發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)Mybatis-Plus如何實(shí)現(xiàn)批量插入,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

Mybatis PlusIService 接口中提供了批量插入的方法,然而,它的內(nèi)部實(shí)現(xiàn)邏輯竟然是這樣的:

Mybatis-Plus如何實(shí)現(xiàn)批量插入

居然是循環(huán)單條插入?!逗人玩嘛,好吧,自己動(dòng)手,豐衣足食。

一. 添加依賴

<!--mybatis plus extension,包含了mybatis plus core-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-extension</artifactId>
    <version>3.4.0</version>
</dependency>

二. 繼承默認(rèn)方法注入

在 injector 包下新建 EasySqlInjector.java

Mybatis-Plus如何實(shí)現(xiàn)批量插入

EasySqlInjector.java

import com.baomidou.mybatisplus.core.injector.AbstractMethod;
import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector;
import com.baomidou.mybatisplus.extension.injector.methods.InsertBatchSomeColumn;
import java.util.List;

/**
 * @author: jichunyang
 * @description: 自定義數(shù)據(jù)方法注入
 * @date: 2020/12/18 14:15
 **/
public class EasySqlInjector extends DefaultSqlInjector {

    @Override
    public List<AbstractMethod> getMethodList(Class<?> mapperClass) {
        List<AbstractMethod> methodList = super.getMethodList(mapperClass);
        methodList.add(new InsertBatchSomeColumn());
        return methodList;
    }
}

三. 在 MybatisPlusConfig 配置文件中注入 Bean

//開啟事務(wù)
@EnableTransactionManagement
@Configuration
@MapperScan("掃描的mapper包路徑")
public class MybatisPlusConfig {
	
	//需要注入的Bean
	@Bean
    public EasySqlInjector easySqlInjector() {
        return new EasySqlInjector();
    }
    
	@Bean("sqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory() throws Exception {
        MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean();
        // 其他配置項(xiàng)
        ......
        sqlSessionFactory.setGlobalConfig(globalConfiguration());
        return sqlSessionFactory.getObject();
    }

    @Bean
    public GlobalConfig globalConfiguration() {
        GlobalConfig conf = new GlobalConfig();
        // 自定義的注入需要在這里進(jìn)行配置
        conf.setSqlInjector(easySqlInjector());
        return conf;
    }
}

四. 擴(kuò)展自帶 BaseMapper

在 mapper 包下新建 EasyBaseMapper 接口,擴(kuò)展自帶 BaseMapper

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import java.util.List;

public interface EasyBaseMapper<T> extends BaseMapper<T> {

    /**
     * 批量插入 僅適用于mysql
     * @param entityList 實(shí)體列表
     * @return 影響行數(shù)
     */
    Integer insertBatchSomeColumn(List<T> entityList);
}

五. 業(yè)務(wù)層面實(shí)現(xiàn)

修改業(yè)務(wù) mapper 接口 UserMapper,繼承剛剛擴(kuò)展的 EasyBaseMapper

import org.apache.ibatis.annotations.Mapper;

/**
 * @author jichunyang
 * @description 用戶Mapper
 */
@Mapper
public interface UserMapper extends EasyBaseMapper<User> {

}

service實(shí)現(xiàn)層的使用

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.stereotype.Service;

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements IUserService {
	
    @Override
    @Transactional
    public void insertUsers(List<User> users) {
	    // 這里使用了自定義的批量插入,baseMapper可以直接使用,不需要聲明
	    baseMapper.insertBatchSomeColumn(users);
	}
}

IUserService 是定義的業(yè)務(wù)邏輯接口,和批量插入配置無關(guān);

關(guān)于“Mybatis-Plus如何實(shí)現(xiàn)批量插入”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI