这篇文章将为大家详细讲解有关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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。