mybatisplus乐观锁

Posted Y-wee

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatisplus乐观锁相关的知识,希望对你有一定的参考价值。

mybatisplus乐观锁

乐观锁 : 故名思意十分乐观,它总是认为不会出现问题,无论干什么不去上锁!如果出现了问题,再次更新值测试

悲观锁:故名思意十分悲观,它总是认为总是出现问题,无论干什么都会上锁!再去操作!

乐观锁实现机制:

  • 取出记录时,获取当前 version
  • 更新时,带上这个version
  • 执行更新时, set version = newVersion where version = oldVersion
  • 如果version不对,就更新失败
乐观锁:1、先查询,获得版本号 version = 1 
-- A 
update user set name = "kuangshen", version = version + 1 where id = 2 and version = 1 
-- B 线程抢先完成,这个时候 version = 2,会导致 A 修改失败! 
update user set name = "kuangshen", version = version + 1 where id = 2 and version = 1

mybatisplus乐观锁实现案例

  • 给数据库增加version字段

  • 实体类加对应字段

    @Version //乐观锁Version注解 
    private Integer version;
    
  • 编写配置类,注册组件

    @MapperScan("com.kuang.mapper")// 扫描我们的 mapper 文件夹
    @EnableTransactionManagement //开启事务控制
    @Configuration // 配置类 
    public class MyBatisPlusConfig { 
        // 注册乐观锁插件 
        @Bean public OptimisticLockerInterceptor optimisticLockerInterceptor() {
            return new OptimisticLockerInterceptor();
        } 
    }
    

以上是关于mybatisplus乐观锁的主要内容,如果未能解决你的问题,请参考以下文章

MyBatisPlus学习乐观锁 OptimisticLockerInnerInterceptor插件 细解

MybatisPlus 学习乐观锁

MyBatisPlus如何实现乐观锁

[MyBatisPlus]乐观锁和悲观锁

[MyBatisPlus]乐观锁和悲观锁

MyBatis Plus乐观锁常用配置