MybatisPlus实现insertBatchSomeColumn进行批量增加
更新时间:2023年03月17日 09:52:03 作者:林卓淇
本文主要介绍了MybatisPlus实现insertBatchSomeColumn进行批量增加,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
1、引入相关依赖
<!--mybatis-plus启动器--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.1</version> </dependency> <!--mybatis-plus扩展插件依赖--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-extension</artifactId> <version>3.5.1</version> </dependency>
2、编写sql注入器
package com.linmain.mysql.config;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.core.injector.AbstractMethod;
import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector;
import com.baomidou.mybatisplus.core.metadata.TableInfo;
import com.baomidou.mybatisplus.extension.injector.methods.InsertBatchSomeColumn;
import java.util.List;
/**
* @Author linzhuoqi
* @Date 2023/3/10
* @Eamil 1580752420@qq.com
* @Version
* @Description 自定义的sql注入器,插入了批量插入的方法
*/
public class EasySqlInjector extends DefaultSqlInjector {
@Override
public List<AbstractMethod> getMethodList(Class<?> mapperClass, TableInfo tableInfo) {
// 注意:此SQL注入器继承了DefaultSqlInjector(默认注入器),调用了DefaultSqlInjector的getMethodList方法,保留了mybatis-plus的自带方法
List<AbstractMethod> methodList = super.getMethodList(mapperClass, tableInfo);
//增加了一个批量插入的方法
methodList.add(new InsertBatchSomeColumn(i -> i.getFieldFill() != FieldFill.UPDATE));
return methodList;
}
}3、在mybatisPlus的配置类中注入插件
@Configuration
public class MyBatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
//添加分页插件
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
//添加乐观锁插件
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
return interceptor;
}
@Bean
public EasySqlInjector easySqlInjector() {
return new EasySqlInjector();
}
}4、编写dao层接口
package com.linmain.column.dao;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.linmain.column.pojo.entity.ColTag;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
/**
* 专栏标签(ColTag)表数据库访问层
*
* @Author linzhuoqi
* @Date 2023-03-02 20:44:38
* @Eamil 1580752420@qq.com
* @Version
* @Description
*/
@Mapper
public interface ColTagDao extends BaseMapper<ColTag> {
/**
* 批量插入 仅适用于mysql
*
* @param entityList 实体列表
* @return 影响行数
*/
Integer insertBatchSomeColumn(Collection<ColTag> entityList);
}5、最后
进行正常的使用即可
colTagDao.insertBatchSomeColumn(colTags);
到此这篇关于MybatisPlus实现insertBatchSomeColumn进行批量增加的文章就介绍到这了,更多相关MybatisPlus insertBatchSomeColumn批量增加内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Invalid bound statement (not found)出现原因以及解决办法
这篇文章主要给大家介绍了关于Invalid bound statement (not found)出现原因以及解决办法的相关资料,文中给出了详细的解决方法,需要的朋友可以参考下2023-07-07
浅谈java中为什么重写equals后需要重写hashCode
今天带各位学习一下java中为什么重写equals后需要重写hashCode,文中有非常详细的图文介绍及代码示例,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下2021-05-05
在spring-boot工程中添加spring mvc拦截器
这篇文章主要介绍了在spring-boot工程中添加spring mvc拦截器,Spring MVC的拦截器(Interceptor)不是Filter,同样可以实现请求的预处理、后处理。,需要的朋友可以参考下2019-06-06


最新评论