本文共 809 字,大约阅读时间需要 2 分钟。
声明,目前只是仅仅针对3.0以下版本,2.0以上版本。
意图:
当要更新一条记录的时候,希望这条记录没有被别人更新
乐观锁实现方式:
取出记录时,获取当前version更新时,带上这个version执行更新时, set version = yourVersion+1 where version = yourVersion如果version不对,就更新失败
第一步,配置
SSM框架(Spring+SpringMVC+MyBatis-Plus):
spring-mybatis.xml配置:
SpringBoot配置:
@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() { return new OptimisticLockerInterceptor();}
第二步,加上注解
public class User {
@Versionprivate Integer version;
}
特别说明: 仅支持int,Integer,long,Long,Date,Timestamp
测试代码:
int id = 100;
int version = 2;User u = new User();
u.setId(id);u.setVersion(version);if(userService.updateById(u)){
System.out.println("Update successfully");
}else{
System.out.println("Update failed due to modified by others");
}
示例SQL原理:
update tbl_user set name='update',version=3 where id=100 and version=2;
转载地址:http://fngia.baihongyu.com/