Mybatis-Plus如何实现批量插入
发表于:2025-11-11 作者:千家信息网编辑
千家信息网最后更新 2025年11月11日,这篇文章将为大家详细讲解有关Mybatis-Plus如何实现批量插入,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Mybatis Plus 的 IService 接
千家信息网最后更新 2025年11月11日Mybatis-Plus如何实现批量插入
这篇文章将为大家详细讲解有关Mybatis-Plus如何实现批量插入,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
Mybatis Plus 的 IService 接口中提供了批量插入的方法,然而,它的内部实现逻辑竟然是这样的:
居然是循环单条插入?!逗人玩嘛,好吧,自己动手,丰衣足食。
一. 添加依赖
com.baomidou mybatis-plus-extension 3.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 { @Override public 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 @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 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 @Transactional public void insertUsers(List users) { // 这里使用了自定义的批量插入,baseMapper可以直接使用,不需要声明 baseMapper.insertBatchSomeColumn(users); }}
IUserService 是定义的业务逻辑接口,和批量插入配置无关;
关于"Mybatis-Plus如何实现批量插入"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
接口
配置
业务
方法
篇文章
更多
逻辑
不错
实用
逗人
丰衣足食
事务
内容
实体
层面
数据
文件
文章
用户
知识
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
银行ra服务器是什么意思
一个服务器可以同时训练多个模型
安全服务器网络SSN
北京华盛网络技术有限公司
大话西游2服务器叫什么
广州苹果软件开发培训
服务器上无法连接打印机
数据库查出来的如何排序
公安机关网络安全协议
东莞hp服务器维修
有关网络安全的海报
数据库原理及应用什么是关系
安全通告网络安全世界
安全狗服务器证书变更
用自家网络做服务器
海南球员数据库
狗策划服务器怎么样
英雄联盟重置后找不到服务器
总结类数据库
邮件安全连接到服务器地址
东山租房网络安全
数据库大致可分为
安全服务器网络SSN
数据库现状发展
金融行业和软件开发
通信网络安全与防护课后答案
正胃胶囊药品广告数据库
服务器包含的分类有哪些
网站重启服务器要多久
软件开发企业账务处理复杂吗