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

居然是循環(huán)單條插入?!逗人玩嘛,好吧,自己動手,豐衣足食。
一. 添加依賴
<!--mybatis plus extension,包含了mybatis plus core-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-extension</artifactId>
<version>3.4.0</version>
</dependency>
二. 繼承默認方法注入
在 injector 包下新建 EasySqlInjector.java

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();
// 其他配置項
......
sqlSessionFactory.setGlobalConfig(globalConfiguration());
return sqlSessionFactory.getObject();
}
@Bean
public GlobalConfig globalConfiguration() {
GlobalConfig conf = new GlobalConfig();
// 自定義的注入需要在這里進行配置
conf.setSqlInjector(easySqlInjector());
return conf;
}
}
四. 擴展自帶 BaseMapper
在 mapper 包下新建 EasyBaseMapper 接口,擴展自帶 BaseMapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import java.util.List;
public interface EasyBaseMapper<T> extends BaseMapper<T> {
/**
* 批量插入 僅適用于mysql
* @param entityList 實體列表
* @return 影響行數(shù)
*/
Integer insertBatchSomeColumn(List<T> entityList);
}
五. 業(yè)務(wù)層面實現(xiàn)
修改業(yè)務(wù) mapper 接口 UserMapper,繼承剛剛擴展的 EasyBaseMapper
import org.apache.ibatis.annotations.Mapper;
/**
* @author jichunyang
* @description 用戶Mapper
*/
@Mapper
public interface UserMapper extends EasyBaseMapper<User> {
}
service實現(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);
參考博客:http://www.dhdzp.com/article/196445.htm
到此這篇關(guān)于Mybatis Plus 實現(xiàn)批量插入的示例代碼的文章就介紹到這了,更多相關(guān)Mybatis Plus批量插入內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
一篇文章帶你深入理解JVM虛擬機讀書筆記--鎖優(yōu)化
這篇文章深入介紹了JVM虛擬機的鎖優(yōu)化,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2021-09-09
springcloud?feign?接口指定接口服務(wù)ip方式
這篇文章主要介紹了springcloud?feign?接口指定接口服務(wù)ip方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot實現(xiàn)全局異常的封裝和統(tǒng)一處理
在Spring Boot應(yīng)用中,全局異常的處理是一個非常重要的方面,本文主要為大家詳細介紹了如何在Spring Boot中進行全局異常的封裝和統(tǒng)一處理,需要的可以參考下2023-12-12
java數(shù)據(jù)類型轉(zhuǎn)換陷阱包括列表陷阱
這篇文章主要介紹了java數(shù)據(jù)類型轉(zhuǎn)換的一些陷阱,包括基本數(shù)據(jù)類型轉(zhuǎn)換列表陷阱,基本上這一篇就把常見的問題就給大家分享一下2020-10-10
SpringBoot+shardingsphere實現(xiàn)按月分表功能教程
這篇文章主要介紹了SpringBoot+shardingsphere實現(xiàn)按月分表功能教程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2025-04-04
Java設(shè)置Access-Control-Allow-Origin允許多域名訪問的實現(xiàn)方法
這篇文章主要介紹了Java設(shè)置Access-Control-Allow-Origin允許多域名訪問的實現(xiàn)方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-10-10

