学习目标:
学习内容:
- 什么是乐观锁
- 乐观锁实现步骤
一、什么是乐观锁
乐观锁:就是当要更新一条记录的时候,希望这条记录没有被别人更新,从而实现线程安全的数据更新。解决丢失更新的问题
个人理解,假如有A和B俩个人,A去查询数据返回 “张三” 准备将名字改成 “李四” 还没有提交数据,同时B也查询到了这条数据 “张三” 准备将名字改成 “王五” 并且B已经提交数据,这时候A也提交数据,然后B就会发现直接明明改的是 “王五” 怎么变成 “李四” 了 然后B一脸问号???
这就是因为A的提交导致了B的数据更新丢失。
二.mp实现乐观锁
第一步首先在数据库加上version字段
第二步:在代码的实体类上加上 @Version注解
@Version
private Integer version;
第三步:增加配置类,配置乐观锁插件,需要引入依赖
@EnableTransactionManagement
@Configuration
public class MybatisPlusConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}
}
第四步:自动填充
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill.....");
Date date = new Date();
this.setFieldValByName("created", date, metaObject);
this.setFieldValByName("updated", date, metaObject);
this.setFieldValByName("version", 0, metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill.....");
this.setFieldValByName("updated",new Date(),metaObject);
}
}
第五步:就修改这个root用户,看他版本号会不会变,目前是0
测试:我就使用swagger-ui对这个用户进行修改, 版本号也被修改了
|