6. MyBatisPlus实现乐观锁
程序员文章站
2022-09-05 12:59:21
MyBatisPlus实现乐观锁1. 数据库中添加version字段2. 实体类添加version字段3. 元对象处理器接口添加version的insert默认值4. 在 MybatisPlusConfig 中注册 Bean5. 测试乐观锁可以修改成功6. 测试乐观锁修改失败☆主要适用场景:当要更新一条记录的时候,希望这条记录没有被别人更新,也就是说实现线程安全的数据更新...
文章目录
MyBatisPlus实现乐观锁
主要适用场景:
当要更新一条记录的时候,希望这条记录没有被别人更新,也就是说实现线程安全的数据更新
乐观锁实现方式:
- 取出记录时,获取当前version
- 更新时,带上这个version
执行更新时, set version = newVersion where version = oldVersion
- 如果version不对,就更新失败
1. 数据库中添加version字段
ALTER TABLE `user` ADD COLUMN `version` INT
2. 实体类添加version字段
// 并添加 @Version 注解
@Version
@TableField(fill = FieldFill.INSERT)
private Integer version;
3. 元对象处理器接口添加version的insert默认值
@Override
public void insertFill(MetaObject metaObject) {
......
this.setFieldValByName("version", 1, metaObject);
}
特别说明:
支持的数据类型只有
int,Integer,long,Long,Date,Timestamp,LocalDateTime
整数类型下
newVersion = oldVersion + 1
newVersion
会回写到entity
中仅支持updateById(id)
与update(entity, wrapper)
方法在
update(entity, wrapper)
方法下,wrapper
不能复用!!
4. 在 MybatisPlusConfig 中注册 Bean
创建配置类
@EnableTransactionManagement
@Configuration
@MapperScan("com.atguigu.mybatis_plus.mapper"
OptimisticLockerInterceptor类
package cn.justweb.mybatisplus.config;
@EnableTransactionManagement
@Configuration
@MapperScan("cn.justweb.mybatisplus.mapper")
public class MybatisPlusConfig {
/**
* 乐观锁插件
*/
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}
5. 测试乐观锁可以修改成功
测试后分析打印的
sql
语句,将version的数值进行了加1操作
/**
* 测试 乐观锁插件
*/
@Test
public void testOptimisticLocker() {
//查询
User user = userMapper.selectById(1L);
//修改数据
user.setName("Helen Yao2");
user.setEmail("helen@qq.com");
//执行更新
userMapper.updateById(user);
}
6. 测试乐观锁修改失败
/**
* 测试 乐观锁失败
*/
@Test
public void testOptimisticLockerFail() {
//查询
User user = userMapper.selectById(1248825496112750594L);
//修改数据
user.setName("Helen Yao222");
user.setEmail("helen22@qq.com");
// 模拟取出数据,数据库中的version实际比取出的值大,即以被其他线程修改并更新了version
user.setVersion(user.getVersion()-1);
//执行更新
userMapper.updateById(user);
}
☆
本文地址:https://blog.csdn.net/weixin_45267102/article/details/108984154
上一篇: 使用子查询