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

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

控制台:

相关推荐
hexu_blog1 天前
vue+java实现图片批量压缩
java·前端·vue.js
头歌实践平台1 天前
Hadoop开发环境搭建
java·大数据·hadoop
Seven971 天前
一致性Hash算法:如何实现分布式系统中的高效数据分片?
java
摇滚侠1 天前
IDEA 生成 try catch 快捷键
java·ide·intellij-idea
阿旭超级学得完1 天前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表
掉鱼的猫1 天前
Spring AI 2.0 GA 倒计时:先别急,来看看 Java AI 框架的另一条路
java·openai·agent
Refrain_zc1 天前
Android 应用内 APK 安装全方案:从静默安装到普通安装的详解
java
正儿八经的少年1 天前
Spring Boot 两种激活配置方式的作用与区别
java·spring boot·后端
云烟成雨TD1 天前
Spring AI Alibaba 1.x 系列【52】Interrupts 中断机制:节点执行前后静态中断
java·人工智能·spring