Mybatis-Plus如何实现批量插入
发表于:2024-10-25 作者:千家信息网编辑
千家信息网最后更新 2024年10月25日,这篇文章将为大家详细讲解有关Mybatis-Plus如何实现批量插入,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Mybatis Plus 的 IService 接
千家信息网最后更新 2024年10月25日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安全错误
数据库的锁怎样保障安全
的软件开发
数据库系统中的主要模型有
人事档案管理数据服务器
数据库从入门到删库
数据库如何创建一对一关系
sql 数据库期末题库
量子数据库机房计价标准
中国台湾oa软件开发系统
深圳凯荣网络技术有限公司
代驾公司软件开发商
数据库安全性设计分为哪三步
舒曼计划表软件开发
如何将动态实体存入数据库
芜湖计算机软件开发培训班
互联网科技平台
电脑玩王者荣耀服务器
中兴深圳软件开发部门
网络安全工程师工作地分析
软件开发商项目经理工资
网络安全菜刀事件
现代化综合数据库
网站国外服务器多少钱
穿越火线人数最多的服务器
网络安全逃生图是什么
梦幻西游全服务器成就
肥东软件开发专业
河西区高科技软件开发服务供应
网络安全工程师工作地分析
操作access数据库
怎么查询sql2008数据库