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
相关推荐
x***38164 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
故事不长丨4 小时前
C#定时器与延时操作的使用
开发语言·c#·.net·线程·定时器·winform
hefaxiang4 小时前
C语言常见概念(下)
c语言·开发语言
S***84884 小时前
SpringSecurity踢出指定用户
java
p***s914 小时前
Spring数据库原理 之 DataSource
java·数据库·spring
adobehu4 小时前
麒麟系统安装jdk17
java·jdk
欧阳天风4 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
spencer_tseng4 小时前
java.util.IllegalFormatPrecisionException
java·printf
虹科网络安全4 小时前
艾体宝干货 | Redis Java 开发系列#1 从零开始的环境搭建与实践指南
java·数据库·redis
铅笔侠_小龙虾5 小时前
Arthas 命令
java·jvm