简单示例演示:乐观锁实现之《版本号》

乐观锁主要有两种实现方式:版本号机制和 CAS(Compare And Swap,比较并交换)机制。下面分别介绍:

1. 版本号机制

版本号机制通过为数据添加版本标识,每次更新时检查版本是否匹配来判断是否有并发冲突。

代码示例:

1.创建实体:

java 复制代码
@lombok.Data
@lombok.AllArgsConstructor
@lombok.NoArgsConstructor
public class Data {
    /**
     * 实体类
     */
        private int id;
        private int version;
        private String value;

}

2.创建一个controller

java 复制代码
@RestController
@RequestMapping("/versionOptimisticLock")
public class VersionOptimisticLockController {

    @Autowired
    private VersionOptimisticLockMapper mapper;

    @PutMapping("/update")
    public void update(@RequestBody Data data) {
        Data dataById = mapper.getById(data.getId());//获取数据库中的数据
        try {
            TimeUnit.SECONDS.sleep(2);
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }
        int affectRows = mapper.update(dataById);
        if (affectRows == 0) {
            throw new RuntimeException("更新失败");
        }
        System.out.println("更新成功");
    }

}

创建mapper:

java 复制代码
@Mapper
public interface VersionOptimisticLockMapper {
   @Update("update optimisticlockTable set value=#{value},version=version+1 where id=#{id} and version=#{version}")
    int update(Data data);

   @Select("select id, value, version from optimisticlockTable where id= #{id} ")
    Data getById(int id);
}

使用postman等工具进行测试,发送两个请求同时,结果肯定是一个成功一个失败。

控制台:

相关推荐
_Jimmy_18 小时前
Nacos的三层缓存是什么
java·缓存
朝新_18 小时前
【实战】动态 SQL + 统一 Result + 登录校验:图书管理系统(下)
xml·java·数据库·sql·mybatis
百***920219 小时前
java进阶1——JVM
java·开发语言·jvm
迦蓝叶19 小时前
RDF 与 RDFS:知识图谱推理的基石
java·人工智能·数据挖掘·知识图谱·语义网·rdf·rdfs
百锦再19 小时前
选择Rust的理由:从内存管理到抛弃抽象
android·java·开发语言·后端·python·rust·go
yaoxin52112319 小时前
238. Java 集合 - 使用 ListIterator 遍历 List 元素
java·python·list
爱分享的Shawn_Salt19 小时前
IntelliJ IDEA初始化指南
java·ide·intellij-idea
Dxxyyyy19 小时前
零基础学JAVA--Day32(ArrayList底层+Vector+LinkedList)
java·开发语言
Pluchon19 小时前
硅基计划6.0 柒 JavaEE 浅谈JVM&GC垃圾回收
java·jvm·数据结构·java-ee·gc
whatever who cares19 小时前
在Java/Android中,List的属性和方法
android·java