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
相关推荐
郑州光合科技余经理2 分钟前
海外版外卖系统:如何快速搭建国际化外卖平台
java·开发语言·前端·人工智能·小程序·系统架构·php
Cheng小攸4 分钟前
协议分析与分析工具(一)
开发语言·php
fox_lht6 分钟前
14.2.读文件
开发语言·后端·rust
codeejun6 分钟前
每日一Go-74、Go 云原生可观测性实战之OpenTelemetry 全链路采集:Trace + Metrics + Logs
开发语言·云原生·golang
Yvonne爱编码7 分钟前
JAVA EE初阶---DAY 1 计算机是如何工作的
java·java-ee
神仙别闹8 分钟前
基于 Python 实现 ANN 与 KNN 的图像分类
开发语言·python·分类
yugi9878388 分钟前
基于Qt的实用二维码生成解决方案
开发语言·qt
_小许_9 分钟前
Go语言导入与导出excel文件
开发语言·golang·excel
SilentSamsara11 分钟前
高并发 API 压测与调优:locust + 火焰图 + 瓶颈定位
开发语言·python·青少年编程·docker·中间件
myenjoy_113 分钟前
开源!Go+Wails+Vue3 手搓一个 PLC 实时监控桌面工具
开发语言·golang·开源