乐观锁

乐观锁

主要用于解决丢失更新问题

乐观锁

 

乐观锁的实现 

1、数据库表添加字段,作为乐观锁版本号

2、对应实体类添加版本号属性乐观锁

 

3、配置乐观锁插件

//这是一个配置类
@Configuration
@MapperScan("com.lei.mybatis_plus.mapper")
public class MybatisPlusConfig {

    //乐观锁插件
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor(){
        return new OptimisticLockerInterceptor();
    }
}

 

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

    //使用mp实现添加这个操作,这个方法执行
    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("createTime",new Date(),metaObject);
        this.setFieldValByName("updateTime",new Date(),metaObject);
        this.setFieldValByName("version",1,metaObject);
    }
    //使用mp实现更新这个操作,这个方法执行
    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime",new Date(),metaObject);
    }
}

4、测试乐观锁

//测试乐观锁,先查询,后更新,更新前version=1,更新后version=2
@Test
public void OptimisticLockerTest(){

    //根据id查询数据
    User user=userMapper.selectById(1261993075279499265L);
    user.setName("喜之郎啊");
    int i = userMapper.updateById(user);
    System.out.println(i);
}