Mybatis|Mybatis Plus 实现批量插入的示例代码
目录
- 一. 添加依赖
- 二. 继承默认方法注入
- 三. 在 MybatisPlusConfig 配置文件中注入 Bean
- 四. 扩展自带 BaseMapper
- 五. 业务层面实现
文章图片
居然是循环单条插入?!逗人玩嘛,好吧,自己动手,丰衣足食。
一. 添加依赖
com.baomidou mybatis-plus-extension3.4.0
二. 继承默认方法注入 在 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 {@Overridepublic List getMethodList(Class> mapperClass) {List methodList = super.getMethodList(mapperClass); methodList.add(new InsertBatchSomeColumn()); return methodList; }}
三. 在 MybatisPlusConfig 配置文件中注入 Bean
//开启事务@EnableTransactionManagement@Configuration@MapperScan("扫描的mapper包路径")public class MybatisPlusConfig { //需要注入的Bean @Beanpublic EasySqlInjector easySqlInjector() {return new EasySqlInjector(); } @Bean("sqlSessionFactory")public SqlSessionFactory sqlSessionFactory() throws Exception {MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean(); // 其他配置项......sqlSessionFactory.setGlobalConfig(globalConfiguration()); return sqlSessionFactory.getObject(); }@Beanpublic 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 EasyBaseMapperextends BaseMapper {/*** 批量插入 仅适用于mysql* @param entityList 实体列表* @return 影响行数*/Integer insertBatchSomeColumn(List entityList); }
五. 业务层面实现 修改业务 mapper 接口 UserMapper,继承刚刚扩展的 EasyBaseMapper
import org.apache.ibatis.annotations.Mapper; /** * @author jichunyang * @description 用户Mapper */@Mapperpublic interface UserMapper extends EasyBaseMapper{}
service实现层的使用
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.springframework.stereotype.Service; @Servicepublic class UserServiceImpl extends ServiceImplimplements IUserService { @Override@Transactionalpublic void insertUsers(List users) {// 这里使用了自定义的批量插入,baseMapper可以直接使用,不需要声明baseMapper.insertBatchSomeColumn(users); }}
IUserService 是定义的业务逻辑接口,和批量插入配置无关;
参考博客:https://www.jb51.net/article/196445.htm
【Mybatis|Mybatis Plus 实现批量插入的示例代码】到此这篇关于Mybatis Plus 实现批量插入的示例代码的文章就介绍到这了,更多相关Mybatis Plus批量插入内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- 关于QueryWrapper|关于QueryWrapper,实现MybatisPlus多表关联查询方式
- mybatisplus如何在xml的连表查询中使用queryWrapper
- mybatisplus|mybatisplus where QueryWrapper加括号嵌套查询方式
- MybatisPlus|MybatisPlus LambdaQueryWrapper使用int默认值的坑及解决
- MybatisPlus使用queryWrapper如何实现复杂查询
- python学习之|python学习之 实现QQ自动发送消息
- 孩子不是实现父母欲望的工具——林哈夫
- opencv|opencv C++模板匹配的简单实现
- Node.js中readline模块实现终端输入
- java中如何实现重建二叉树