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

- 2.实现步骤
- (1)给数据库增加version字段

- (2) 在实体类添加相应的字段和注解
@Version
private int version;
- (3)注册组件
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;
/**
* @Author Janson
* @Date 2022/3/14 16:14
* @Version 1.0
*/
@Configuration
@MapperScan("com.janson.mybatis_plus.mapper")
public class MybatisPlusConfig {
//注册乐观锁插件
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {
return new OptimisticLockerInterceptor();
}
}
- (4)测试乐观锁
- 单线程操作
@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(){
//多线程操作乐观锁
//线程1操作,此时 version = 1
User user = userMapper.selectById(4L);
user.setName("66666");
user.setAge(100);
//线程2抢占执行
User user2 = userMapper.selectById(4L);
user2.setName("88888");
user2.setAge(200);
int i2 = userMapper.updateById(user2);
//执行完成后 version 变为 2
System.out.println(i2);
//线程1 继续执行,但是此时发现version = 2,无法满足 version = 1 的要求,无法进行覆盖
//如果没有乐观锁,线程 1 会进行覆盖线程 2 的修改
int i = userMapper.updateById(user);
System.out.println(i);
}
注意:在加入乐观锁之后,可能会出现自动填充更新失效的情况。若出现这种情况,可以在自动填充的注解中添加 update = “now()” 就能解决该问题。
@TableField(fill = FieldFill.UPDATE,update = "now()")

被折叠的 条评论
为什么被折叠?



