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
相关推荐
绛洞花主敏明5 分钟前
Go操作xorm中间表多对多关联实战
开发语言·后端·golang
噢,我明白了6 分钟前
MyBatis-Plus 中IPage的分页查询
java·mybatis
Jun6267 分钟前
QT(4)-EXCEL操作
开发语言·qt·excel
fengfuyao98510 分钟前
基于MATLAB的HHT变换完整实现(含EMD分解与三维时频谱生成)
开发语言·算法·matlab
剑挑星河月10 分钟前
98.验证二叉搜索树
java·算法·leetcode
我登哥MVP20 分钟前
Spring Boot 从“会用”到“精通”:请求映射原理
java·spring boot·后端·spring·servlet·maven·intellij-idea
luj_176821 分钟前
马克思的跨学科学术体系
c语言·开发语言·c++·经验分享·算法
阿文的代码库27 分钟前
干货分享|C++运算符重载知识点
java·c++·算法
码不停蹄的玄黓27 分钟前
Java 实现阻塞队列
java·开发语言
SunnyDays101127 分钟前
Java 实现 PDF 转 PDF/A 和 PDF/A 转 PDF(超详细教程)
java·开发语言·pdf