引入mybatis-plus依赖,注意这里的版本要求 since 3.4.0;(3.4.1,3.4.2已测)
3.2.0肯定是不支持的,无法引入MybatisPlusInterceptor
;
乐观锁
当要更新一条记录的时候,希望这条记录没有被别人更新
配置工作
- 实例化
OptimisticLockerInnerInterceptor
,并添加到MyBatis-Plus
的拦截器链中;
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
mybatisPlusInterceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
return mybatisPlusInterceptor;
}
- 在Entity中定义
version
字段,并加上@Version
注解。
@Version
private Integer version;
参照官网文档
实现方式
- 取出记录时,获取当前version
- 更新时,带上这个version
- 执行更新时, set version = newVersion where version = oldVersion
- 如果version不对,就更新失败
注意事项
说明:
- 支持的数据类型只有:int,Integer,long,Long,Date,Timestamp,LocalDateTime
- 整数类型下
newVersion = oldVersion + 1
newVersion
会回写到entity
中- 仅支持
updateById(id)
与update(entity, wrapper)
方法entity
的版本字段必须有值,否则不会生成乐观锁SQL- 在
update(entity, wrapper)
方法下,wrapper
不能复用!!!
参考文档
mybatis-plus乐观锁插件
mybatis-plus基于@Version注解的乐观锁实现
Mybatis-Plus基于@Version注解的乐观锁实现及两个坑