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.dbjr.com.cn/article/196445.htm
到此這篇關(guān)于Mybatis Plus 實現(xiàn)批量插入的示例代碼的文章就介紹到這了,更多相關(guān)Mybatis Plus批量插入內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot項目中使用OkHttp獲取IP地址的示例代碼
OkHttp?是一個由?Square?開發(fā)的高效、現(xiàn)代的?HTTP?客戶端庫,用于?Android?和?Java?應(yīng)用程序,它支持?HTTP/2?和?SPDY?等現(xiàn)代網(wǎng)絡(luò)協(xié)議,并提供了多種功能和優(yōu)化,本文給大家介紹了SpringBoot項目中如何獲取IP地址,需要的朋友可以參考下2024-08-08IDEA設(shè)置生成帶注釋的getter和setter的圖文教程
通常我們用idea默認生成的getter和setter方法是不帶注釋的,當然,我們同樣可以設(shè)置idea像MyEclipse一樣生成帶有Javadoc的模板,具體設(shè)置方法,大家參考下本文2018-05-05