一、乐观锁
我们经常会听到乐观锁、悲观锁,今天来学习一下!
乐观锁:顾名思义十分乐观,它总是认为不会出现问题,无论干什么都不去上锁! 如果出现了问题,再去上锁。 悲观锁:十分悲观,它总是认为会出现问题,无论干什么都会上锁! 在进行相关操作。
1.乐观锁实现机制
- 取出记录时,获取当前 version
- 更新时,带上这个 version
- 执行更新时, set version = newVersion where version = oldVersion
- 如果 version 不对,就更新失败
 - 2.实现步骤

@Version
private int version;
package com.janson.mybatis_plus.config;
import com.baomidou.mybatisplus.extension.plugins.OptimisticLockerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
@MapperScan("com.janson.mybatis_plus.mapper")
public class MybatisPlusConfig {
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}
@Test
void testOptimisticLocker1(){
User user = userMapper.selectById(4L);
user.setName("66666");
user.setAge(100);
int i = userMapper.updateById(user);
System.out.println(i);
}
@Test
void testOptimisticLocker2(){
User user = userMapper.selectById(4L);
user.setName("66666");
user.setAge(100);
User user2 = userMapper.selectById(4L);
user2.setName("88888");
user2.setAge(200);
int i2 = userMapper.updateById(user2);
System.out.println(i2);
int i = userMapper.updateById(user);
System.out.println(i);
}
注意:在加入乐观锁之后,可能会出现自动填充更新失效的情况。若出现这种情况,可以在自动填充的注解中添加 update = “now()” 就能解决该问题。
@TableField(fill = FieldFill.UPDATE,update = "now()")
|