Mybatis-Plus乐观锁Version

导读:本篇文章讲解 Mybatis-Plus乐观锁Version,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

实现原理

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

实现方式

  1. 数据库中增加一个version字段,默认值为0
    version int(10) NOT NULL DEFAULT ‘0’ COMMENT ‘乐观锁版本号,每次修改+1’
  2. 配置
@Configuration
public class MybatisPlusConfig {
	/**
	 * 乐观锁插件
	 */
	@Bean
	public OptimisticLockerInterceptor optimisticLockerInterceptor() {
		return new OptimisticLockerInterceptor();
	}
}
  1. 实体类加注解
	/**
	 * 乐观锁版本号,每次修改+1
	 */
	@Version
	private Integer version;

在这里插入图片描述
4. 测试
正确写法,目前看了是只支持updateById和update

	@Test
	public void VersionTest(){
		ThreadUtil.put(DefaultConstant.TENANT_ID_KEY, ID);
		ExamPlan examPlan = examPlanMapper.selectById(251L);
		examPlan.setName("测试版本号21");
		examPlanMapper.updateById(examPlan);
		// examPlanMapper.update(examPlan, new LambdaQueryWrapper<ExamPlan>()
		// 		.eq(ExamPlan::getId, examPlan.getId()));				
	}

在这里插入图片描述

下面这里是个坑,没传版本号,可以更新成功,但版本号没有累加,如果随便填了个版本号,会导致此次更新直接失败,还是得先把历史版本号查出来,才能正确更新并且版本号累加

	@Test
	public void VersionTest(){
		ExamPlan examPlan = new ExamPlan();
		examPlan.setId(251L);
		examPlan.setName("测试版本号1");
		examPlanMapper.updateById(examPlan);
		// examPlanMapper.update(examPlan, new LambdaQueryWrapper<ExamPlan>()
		// 		.eq(ExamPlan::getId, examPlan.getId()));		
	}

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/85461.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!