栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

mybatis plus 乐观锁插件

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

mybatis plus 乐观锁插件

主要适用场景

意图:

当要更新一条记录的时候,希望这条记录没有被别人更新

乐观锁实现方式:

取出记录时,获取当前version
更新时,带上这个version
执行更新时, set version = newVersion where version = oldVersion
如果version不对,就更新失败

乐观锁配置需要2步 记得两步

1.插件配置

spring xml:

spring boot:

@Bean
public OptimisticLockerInterceptor optimisticLockerInterceptor() {

return new OptimisticLockerInterceptor();

}

2.注解实体字段 @Version 必须要!

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class OptimisticLocker implements Serializable {

private static final long serialVersionUID = 1L;

@TableId(value = "id", type = IdType.AUTO)
private Integer id;

@TableField("one")
private String one;

@TableField("two")
private Integer two;

@TableField("createTime")
private LocalDateTime createTime;

@Version
private Integer version;

}

特别说明:

支持的数据类型只有:int,Integer,long,Long,Date,Timestamp,LocalDateTime
整数类型下 newVersion = oldVersion + 1
newVersion 会回写到 entity 中
仅支持 updateById(id) 与 update(entity, wrapper) 方法
在 update(entity, wrapper) 方法下, wrapper 不能复用!!!

示例

示例Java代码(参考test case

代码)

    OptimisticLocker o = new OptimisticLocker();
    
    o.setId(1);
    o.setVersion(1);
    o.setTwo(2);
    
    return testService1.update(o);

示例SQL原理

update tbl_user set name = 'update',version = 3 where id = 100 and version = 2

Version 不用手动增加,只需要在更新时,保证是最新的版本数据就行,这样可以保证数据的一致性,但是也增加了业务自身尝试的次数。


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/236401.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号