java并发修改数据,使用乐观锁

java并发修改同一记录时,避免更新丢失,需要加锁。要么在应用层加锁,要么在缓存加锁,要么

在数据库层使用乐观锁,使用 version 作为更新依据。

资金相关的金融敏感信息,使用悲观锁策略,正例:悲观锁遵循一锁二判三更新四释放的原则

在实体类中加上如下注解,由前端统一传更新之前的版本号

java 复制代码
@ApiModelProperty(value = "版本号")
@TableField(value = "VERSION", fill = FieldFill.INSERT, update = "%s+1")
@Version
private Integer version;

在sql执行修改时,sql如下

sql 复制代码
update tablename set version = version+1 where version = oldVersion
相关推荐
专注API从业者3 分钟前
淘宝商品 API 接口架构解析:从请求到详情数据返回的完整链路
java·大数据·开发语言·数据库·架构
独自破碎E5 分钟前
解释一下为什么要有虚拟内存
java
哪里不会点哪里.8 分钟前
Spring 的装配顺序详解(配置 → 扫描 → 注入 → 初始化)
java·sql·spring
木千12 分钟前
Qt全屏显示,在顶部工具栏的最右边显示关闭按钮
开发语言·qt
xiaolyuh12315 分钟前
Spring MVC 深度解析
java·spring·mvc
-凌凌漆-17 分钟前
【java】java中函数加与不加abstract 的区别
java·开发语言
你撅嘴真丑18 分钟前
STL练习
开发语言·c++·算法
❀͜͡傀儡师19 分钟前
SpringBoot与Artemis整合,实现航空行李追踪消息中枢系统
java·spring boot·后端
青云交19 分钟前
Java 大视界 -- Java 大数据在智能交通高速公路收费系统优化与通行效率提升实战
java
Ulyanov21 分钟前
Impress.js深度技术解析:架构基础与结构化设计
开发语言·前端·javascript