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
相关推荐
小高Baby@18 分钟前
使用Go语言中的Channel实现并发编程
开发语言·后端·golang
蓝色汪洋26 分钟前
经典修路问题
开发语言·c++·算法
Knight_AL28 分钟前
Spring AOP 中 JoinPoint 使用指南
java·python·spring
jmxwzy33 分钟前
点赞系统问题
java·redis·tidb·pulsar
ss27336 分钟前
ThreadPoolExecutor:自定义线程池参数
java·开发语言
我有一棵树38 分钟前
解决 highlight.js 不支持语言的方法
开发语言·javascript·ecmascript
invicinble1 小时前
关于fastjson的具体使用案例
java
卜锦元1 小时前
Golang后端性能优化手册(第三章:代码层面性能优化)
开发语言·数据结构·后端·算法·性能优化·golang
墨着染霜华1 小时前
Spring Boot整合Kaptcha生成图片验证码:新手避坑指南+实战优化
java·spring boot·后端
DARLING Zero two♡1 小时前
接入 AI Ping 限免接口,让 GLM-4.7 与 MiniMax-M2.1 成为你的免费 C++ 审计专家
开发语言·c++·人工智能