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

乐观锁主要有两种实现方式:版本号机制和 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等工具进行测试,发送两个请求同时,结果肯定是一个成功一个失败。

控制台:

相关推荐
Boop_wu1 分钟前
简单介绍 JSON
java·开发语言
知识即是力量ol7 分钟前
初识 Kafka(一):分布式流平台的定义、核心优势与架构全景
java·分布式·kafka·消息队列
爱吃生蚝的于勒11 分钟前
【Linux】线程概念(一)
java·linux·运维·服务器·开发语言·数据结构·vim
kong790692812 分钟前
Nginx性能优化
java·nginx·性能优化
Pluchon13 分钟前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
我命由我1234514 分钟前
Java 泛型 - Java 泛型通配符(上界通配符、下界通配符、无界通配符、PECS 原则)
java·开发语言·后端·java-ee·intellij-idea·idea·intellij idea
Seven9714 分钟前
AQS深度探索:以ReentrantLock看Java并发编程的高效实现
java
4311媒体网22 分钟前
C语言操作符全解析 C语言操作符详解
java·c语言·jvm
淡忘_cx23 分钟前
使用Jenkins自动化部署spring-java项目+宝塔重启项目命令(2.528.2版本)
java·自动化·jenkins
毕设源码-钟学长28 分钟前
【开题答辩全过程】以 基于SSM的孤儿救助信息管理系统设计与实现为例,包含答辩的问题和答案
java