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
相关推荐
zh_xuan38 分钟前
kotlin 高阶函数用法
开发语言·kotlin
colicode38 分钟前
安卓Android语音验证码接口API示例代码:Kotlin/Java版App验证开发
android·java·前端·前端框架·kotlin·语音识别
程序员敲代码吗44 分钟前
解析Kotlin中元组的多返回值实现
android·开发语言·kotlin
Java后端的Ai之路1 小时前
【 Java】-网络协议核心知识问答(比较全)
java·开发语言·网络协议
小道仙977 小时前
jenkins对接、jenkins-rest
java·servlet·jenkins·jenkins-rest
莫寒清8 小时前
MinIO
java
姜太公钓鲸23310 小时前
ROM就是程序存储器,实际的存储介质是Flash闪存。上述描述中的程序存储器是什么意思?
开发语言·javascript·ecmascript
Java后端的Ai之路10 小时前
【JDK】-JDK 21 新特性内容
java·开发语言·后端·jdk·jdk21
wjs202411 小时前
JavaScript 作用域
开发语言
m0_5312371711 小时前
C语言-指针终阶
c语言·开发语言