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
相关推荐
小王不爱笑13219 小时前
IO 模型
开发语言·python
短剑重铸之日20 小时前
《ShardingSphere解读》07 读写分离:如何集成分库分表+数据库主从架构?
java·数据库·后端·架构·shardingsphere·分库分表
知我Deja_Vu20 小时前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
AI+程序员在路上20 小时前
CANopen 协议:介绍、调试命令与应用
linux·c语言·开发语言·网络
2401_8318249620 小时前
基于C++的区块链实现
开发语言·c++·算法
m0_5180194820 小时前
C++与机器学习框架
开发语言·c++·算法
ZTLJQ20 小时前
深入理解逻辑回归:从数学原理到实战应用
开发语言·python·机器学习
qq_4176950520 小时前
C++中的代理模式高级应用
开发语言·c++·算法
daidaidaiyu21 小时前
Spring IOC 源码学习 事务相关的 BeanDefinition 解析过程 (XML)
java·spring
波波00721 小时前
每日一题:.NET 中的“反射”是什么?
开发语言·.net