Myabtis-plus乐观锁

原理

当要更新一条记录的时候,希望这条记录没有被别人更新,也就是说实现线程安全的数据更新。

支持的数据类型只有int,Integer,long,Long,Date,Timestamp,LocalDateTime

仅支持 updateById(id) 与 update(entity, wrapper) 方法

1、添加version字段,int类型,不允许为空

2、实体类

@Version
@TableField(fill = FieldFill.INSERT)//自动填充
private Integer version;

3、设置添加默认值

//交给spring管理
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    //使用mp实现添加操作,这个方法会执行,metaObject元数据(表中的名字,表中的字段)
    @Override
    public void insertFill(MetaObject metaObject) {
        //根据名称设置属性值,名称一定要对上
        this.setFieldValByName("version",0,metaObject);
    }
}

4、添加乐观锁插件

@EnableTransactionManagement
@Configuration
@MapperScan("com.yuriki.boot_mb.mapper")
public class MybatisPlusConfig {
    /**乐观锁插件 */
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor(){
        return new OptimisticLockerInterceptor();
    }
}

5、测试

@Test
void update(){
    //需要先查询出结果(version),然后进行更新,乐观锁才能生效
    User user = userMapper.selectById(98);
    user.setPhone("123234");
    userMapper.updateById(user);
}
上一篇:在Linux环境下,将Solr部署到tomcat7中,导入Mysql数据库数据, 定时更新索引


下一篇:Mybatis-plus自动填充