java mybatis 乐观锁_【Mybatis】mybatis plus 乐观锁实现

mybatis plus 中如何实现乐观锁

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

乐观锁实现方式:

取出记录时,获取当前version

更新时,带上这个version

执行更新时, set version = newVersion where version = oldVersion

如果version不对,就更新失败

修改数据表

ALTER TABLE mybatis_plus.`user` ADD COLUMN `version` INT

修改User.java

@Version

@TableField(fill = FieldFill.INSERT)

private Integer version;

添加乐观锁插件

@EnableTransactionManagement

@Configuration

@MapperScan("com.amber.learnmore.mapper")

public class MybatisPlusConfig {

/**

* 乐观锁插件

*/

@Bean

public OptimisticLockerInterceptor optimisticLockerInterceptor() {

return new OptimisticLockerInterceptor();

}

}

测试

先执行insert方法,

@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);

}

查看数据库,可以发现新插入的数据,version为0。

再执行update

@Test

void update() {

User user = userMapper.selectById(1213744199116120065L);

user.setName("amber1");

int i = userMapper.updateById(user);

System.out.println(i);

}

可以看到数据库中的version变成了1,就成功了。

mybatis plus 特别说明

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值