原理
当要更新一条记录的时候,希望这条记录没有被别人更新,也就是说实现线程安全的数据更新。
支持的数据类型只有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);
}