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
相关推荐
Nonoas13 分钟前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
程序员-周李斌1 小时前
Java 死锁
java·开发语言·后端
皮皮林5512 小时前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr2 小时前
CompletableFuture相关问题
java·开发语言
零雲2 小时前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码2 小时前
实现 Trie (前缀树)
开发语言·c#
laocooon5238578862 小时前
插入法排序 python
开发语言·python·算法
你的冰西瓜2 小时前
C++中的list容器详解
开发语言·c++·stl·list
java1234_小锋2 小时前
Java进程占用的内存有哪些部分?
java
就不掉头发2 小时前
I/O复用
运维·服务器·c语言·开发语言