iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis Plus 实现批量插入的示例代码
  • 441
分享到

Mybatis Plus 实现批量插入的示例代码

2024-04-02 19:04:59 441人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录一. 添加依赖二. 继承默认方法注入三. 在 mybatisPlusConfig 配置文件中注入 Bean四. 扩展自带 BaseMapper五. 业务层面实现Mybatis P

Mybatis PlusIService 接口中提供了批量插入的方法,然而,它的内部实现逻辑竟然是这样的:

在这里插入图片描述

居然是循环单条插入?!逗人玩嘛,好吧,自己动手,丰衣足食。

一. 添加依赖


<!--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;


public class EasySqlInjector extends DefaultSqlInjector {

    @Override
    public List<AbstractMethod> getMethodList(Class<?> mapperClass) {
        List<AbstractMethod> 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 EasyBaseMapper<T> extends BaseMapper<T> {

    
    Integer insertBatchSomeColumn(List<T> entityList);
}

五. 业务层面实现

修改业务 mapper 接口 UserMapper,继承刚刚扩展的 EasyBaseMapper


import org.apache.ibatis.annotations.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 是定义的业务逻辑接口,和批量插入配置无关;

参考博客:https://www.jb51.net/article/196445.htm

到此这篇关于Mybatis Plus 实现批量插入的示例代码的文章就介绍到这了,更多相关Mybatis Plus批量插入内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Mybatis Plus 实现批量插入的示例代码

本文链接: https://www.lsjlt.com/news/136624.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作