Mybatis-Plus如何实现批量插入
发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,这篇文章将为大家详细讲解有关Mybatis-Plus如何实现批量插入,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Mybatis Plus 的 IService 接
千家信息网最后更新 2025年01月20日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 ListgetMethodList(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安全错误
数据库的锁怎样保障安全
广州网络安全教育进校园直播
软件开发感兴趣的研究课题
dota2俄罗斯服务器
ppp网络安全
一个请求访问几次数据库
创意网络安全漫画
软件开发资源管理的工具
定制网络技术开发价值
西安的软件开发工资
怎样选择网站服务器
归属地数据库是什么原因
网络安全事件应急预案市场监管
企业网站服务器需要多大
数据库的数据模型三个要素是什么
小翼商服网络技术有限公司
怎样使用数据库算法
java 定时数据库备份
web 文件管理服务器
软件开发公司的预算
2021网络安全宣传片片头
微信服务器无响应怎么办
用大数据解决网络安全
秋光之月服务器
ps数据库进不去
哪个大学用的数据库这本书
南充网络安全海报
正规软件开发定做
深圳市神聊网络技术有限公司
神奇宝贝的服务器地址
北邮网络安全学科评估