這篇文章將為大家詳細講解有關Mybatis-Plus如何實現批量插入,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Mybatis Plus 的 IService 接口中提供了批量插入的方法,然而,它的內部實現邏輯竟然是這樣的:

居然是循環單條插入?!逗人玩嘛,好吧,自己動手,豐衣足食。
<!--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: 自定義數據方法注入
* @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;
}
}//開啟事務
@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;
}
}在 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 影響行數
*/
Integer insertBatchSomeColumn(List<T> entityList);
}修改業務 mapper 接口 UserMapper,繼承剛剛擴展的 EasyBaseMapper
import org.apache.ibatis.annotations.Mapper;
/**
* @author jichunyang
* @description 用戶Mapper
*/
@Mapper
public interface UserMapper extends EasyBaseMapper<User> {
}service實現層的使用
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 是定義的業務邏輯接口,和批量插入配置無關;
關于“Mybatis-Plus如何實現批量插入”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。