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
相关推荐
y***613133 分钟前
【springboot】Spring 官方抛弃了 Java 8!新idea如何创建java8项目
java·spring boot·spring
tanxinji33 分钟前
RabbitMQ四种交换器类型详解及示例
java·rabbitmq
wjs202433 分钟前
Django Nginx+uWSGI 安装配置指南
开发语言
刘一说36 分钟前
一次生产环境 Tomcat 7 + JDK 7 应用启动失败的完整排查与修复实录
java·tomcat·firefox
七夜zippoe1 小时前
JVM类加载机制(Class Loading)详解:双亲委派模型与破坏实践
java·开发语言·jvm·类加载·双亲委派
曹牧1 小时前
C#:无法从方法组转换为objec
开发语言·c#
自动化代码美学2 小时前
【Python3.13】官网学习之控制流
开发语言·windows·python·学习
黄昏恋慕黎明2 小时前
spring MVC了解
java·后端·spring·mvc
coderxiaohan3 小时前
【C++】仿函数 + 模板进阶
开发语言·c++
-Xie-4 小时前
Redis(八)——多线程与单线程
java·数据库·redis