前言 最近在压测一批接口,发现接口处理速度慢的有点超出预期,感觉很奇怪,后面定位发现是数据库批量保存这块很慢。 这个项目用的是mybatis-plus,批量保存直接用的是mybatis-plus提供的 saveBatch。 于是开始排查之路。 一、源码分析 我点进去看了下源码,感觉有点不太对劲。 如下图所示: 我继续追踪了下,从这个代码来看,确实
比如我saveOrUpdate()后,需要用他的id,但是我传进去的对象是没有id的。 代码语言:javascript 代码运行次数:0 运行 AI代码解释 @TestvoidsaveOrUpdate(){UserText userText=newUserText();userText.setUserSex(Sex.MAN);boolean b=userTextService.saveOrUpdate(userText);System.out.println(userText.getUserId...
从这点来看,这个 saveBach 的性能肯定比直接一条一条 insert 快。拼接 sql 的方式实现批量保存效率...
Mybatis-Plus的saveOrUpdateBatch(null)方法在进行批量操作时可能会对性能产生影响。由于该方法会逐条处理数据并执行相应的SQL语句,当数据量较大时,可能会造成较大的性能开销。解决方案: 使用批量操作:考虑使用Mybatis-Plus提供的批量操作方法,如saveOrUpdateBatch(List)或saveOrUpdateBatch(Entity[]),以减少SQL语句的...
在使用 Mybatis-Plus 的 saveBatch() 方法进行批量保存时,有时可能会遇到批量保存失效的问题。这可能是由多种原因引起的,下面是一些可能的原因和相应的解决方案: 数据重复插入:如果在批量保存的数据中存在重复的主键或唯一约束,会导致插入失败。确保每次批量保存的数据都是唯一的,或者在插入前先进行去重处理。 事务...
MyBatis-Plus的BatchSave方法提供了一个批处理插入或更新的接口,可以方便地批量插入或更新数据。具体使用方法如下: 1.引入MyBatis-Plus的依赖 首先需要在项目中引入MyBatis-Plus的依赖,可以通过Maven或Gradle进行添加。 2.创建Mapper接口 在Mapper接口中定义一个BatchSave方法,该方法接受一个List对象作为参数,List对象中...
移除saveBatch 的 @Transactional 注解:这是 MyBatis-Plus 源码的一部分,无法更改。 修改事务传播机制:调整 saveBatch 的传播机制为 REQUIRES_NEW 或 NESTED,但同样无法在 MyBatis-Plus 源码中直接实现。 自定义批量插入:通过自定义批量插入方法...
mybatis-plus 中saveOrUpdateBatch都是采用默认策略(主键)作为判断该数据存在与否的依据,当我们需要使用其他字段作为判断条件的时候,发现不论怎么使用都不行。 这个时候可以采取简单的方式,list在代码里面循环里面使用saveOrUpdate来进行一条一条更新,但是一条一条更新会太慢,当数据太大时也是不行的。
原本使用save时是没有问题了,改成saveOrUpdate 用了一下就报错了。 com.baomidou.mybatisplus.core.exceptions.MybatisPlusException: error: can not execute. because can not find column for id from entity! 就是这个mybatisPlus不能找到哪个是主键字段,因为这个saveOrUpdate默认是根据主键执行操作的! 所有需要...
mybatis-plus 自动生成的service 里面提供的savebatch 最后生成的批量插入语句是多条insert ,而不是insert...vaues (),()的语句,这样是不是跟我们使用循环调用没区别,这样的批量插入是不是有性能问题?下面我们就此问题来进行分析一下。 批量保存的使用方案 ...