mybatis plus 乐观锁实现

使用示例

思路

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

操作

  1. 修改数据库
-- 添加乐观锁字段 (postgres 数据库示例)
ALTER TABLE estate.altima_inspection_task ADD COLUMN version int DEFAULT 0 ;
comment ON  column   estate.altima_inspection_task.version is '乐观锁';
  1. 实体添加乐观锁字段
@Version
@TableField(fill = FieldFill.INSERT)
private Integer version;
  1. 添加乐观锁插件
@EnableTransactionManagement
@Configuration
@MapperScan("com.amber.learnmore.mapper")
public class MybatisPlusConfig {
    /**
     * 乐观锁插件
     */
    @Bean
    public OptimisticLockerInterceptor optimisticLockerInterceptor() {
        return new OptimisticLockerInterceptor();
    }
}
  1. 测试
// 添加
@Test
void insert() {
   User user = new User();
   user.setName("Helen");
   user.setAge(19);
   user.setEmail("7332@qq.com");
   int result = userMapper.insert(user);
   System.out.println(result);
   System.out.println(user);
}
// 修改
@Test
void update() {
    User user = userMapper.selectById(1213744199116120065L);
    user.setName("amber1");
    int i = userMapper.updateById(user);
    System.out.println(i);
}

注意

  1. 支持的数据类型只有 int,Integer,long,Long,Date,Timestamp,LocalDateTime
  2. 仅支持 updateById(id) 与 update(entity, wrapper) 方法

参考:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值