因此我们需要把SQL组装成这种结构,查看InsertBatchSomeColumn类,可以发现SQL组装逻辑在injectMappedStatement方法,因此我们模仿InsertBatchSomeColumn类,编写SQL组装逻辑 importcom.baomidou.mybatisplus.annotation.IdType;importcom.baomidou.mybatisplus.core.enums.SqlMethod;importcom.baomidou.mybatisplus.core.metadata.Table...
一、使用mybatis-plus内置批量插入 mybatis-plus内置提供了InsertBatchSomeCulumn来实现真批量插入,但是由于只支持MySQL的语法格式,所以没有在通用的API作为默认使用。 将InsertBatchSomeCulumn实例放入Sqlnjector列表中 代码语言:java 复制 @BeanpublicDefaultSqlInjectorinsertBatchSqlInject(){returnnewDefaultSqlInjector()...
创建一个自定义的BatchInsert类,继承自AbstractWrapper: import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import...
methodList.add(newInsertBatchSomeColumn(i -> i.getFieldFill() !=FieldFill.UPDATE));returnmethodList; } } 3)注入插件 @ConfigurationpublicclassMyBatisPlusConfig{@BeanpublicMybatisPlusInterceptormybatisPlusInterceptor(){MybatisPlusInterceptorinterceptor =newMybatisPlusInterceptor();//添加分页插件interceptor...
前言:用过mybatis或者mybatis-plus的小伙伴们都知道,工具虽好,偏就是没有实现真正的批量插入,每次都需要手写SQL。今天就基于mybatis-plus实现一个不用写SQL的真正的批量插入 1.添加InsertBatchMethod和UpdateBatchMethod类 继承AbstractMethod packagecom.ahhl.datasource.api.util;importcom.baomidou.mybatisplus.core...
使用for循环进行insert这里就不说了,在海量数据下其性能是最慢的。数据量小的情况下,没什么区别。 【1】saveBatch(一万条数据总耗时:2478ms) mybatisplus扩展包提供的:com.baomidou.mybatisplus.extension.service.IService#saveBatch(java.util.Collection<T>) ...
mybatis-plus提供了InsertBatchSomeColumn批量insert方法。通过SQL 自动注入器接口 ISqlInjector注入通用方法 SQL 语句 然后继承 BaseMapper 添加自定义方法,全局配置 sqlInjector 注入 MP 会自动将类所有方法注入到 mybatis 容器中。我们需要通过这种方式注入下。
@Configurationpublic class MyBatisPlusConfig {/** * 批量操作* * @return*/@Beanpublic InsertBatchSqlInjector sqlInjector() {return new InsertBatchSqlInjector(); }} 到此定义完毕,在Mapper中生成insertBatchSomeColumn(必须是这个方法名)方法。(3)定义一个通用的批量插入接口 public interface...
* 如果只需增加方法,保留mybatis plus自带方法, * 可以先获取super.getMethodList(),再添加add */ @Override public List<AbstractMethod>getMethodList(Class<?>mapperClass){List<AbstractMethod>methodList=super.getMethodList(mapperClass);methodList.add(newInsertBatchMethod());methodList.add(newUpdateBatchMet...
最近在压测mybatis-plus提供的 saveBatch(批量保存方法),因为项目中有接口是直接使用的saveBatch,所以测试下性能,发现处理速度有点慢。 我点进去看了下源码,感觉有点不太对劲: 我继续追踪了下,从这个代码来看,确实是 for 循环一条一条执行了sqlSession.insert,下面的 consumer 执行的就是上面的sqlSession.insert: ...