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
相关推荐
辣椒思密达12 小时前
Python公开数据采集实战:如何解决请求高频拦截与Session会话中断问题
开发语言·python
李白的天不白12 小时前
docker ps
java
Albart57513 小时前
Python 实战教程:用 30 分钟学会解决真实问题
开发语言·python
NE_STOP13 小时前
Docker--Docker Swarm集群
java
2301_7736436213 小时前
ceph池
开发语言·ceph·python
两年半的个人练习生^_^13 小时前
JMM 进阶:彻底理解 CAS 实现原理
java·开发语言
wuminyu13 小时前
Java锁机制之park和unpark源码剖析
java·linux·c语言·jvm·c++
半个烧饼不加肉13 小时前
JS 底层探究-- 事件循环
开发语言·前端·javascript
W_LuYi18513 小时前
手撸极简zkEVM验证器:RISC-V电路实践
java·risc-v
asdfg125896313 小时前
C 语言中产生伪随机数的标准做法
c语言·开发语言