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