乐观锁

在便是过程中,我们经常会被问到乐观锁,悲观锁,都非常简单

我们主要来讲一下乐观锁机会

乐观锁:
1. 先查询,获取版本号version = 1;
A--线程
update air set name = "chougoushi", version = version + i
where id = 2 and version = 1
B--线程如果抢先完成,这个时候version = 2, 会导致A修改失败
update air set name = "chougoushi", version = version + i
where id = 2 and version = 1

测试一下MP(MybatisPLus)

MyBatisPlus乐观锁,乐观锁竟然如此简单-LMLPHP

//测试乐观锁成功
@Test
public void testOptimisticlocker(){
//1.查询用户信息
Air air = airMapper.selectById(1L);
//2.修改用户信息
air.setPm25(44);
air.setPm10(899);
//3.执行更新操作
airMapper.updateById(air); }

MyBatisPlus乐观锁,乐观锁竟然如此简单-LMLPHP

MyBatisPlus乐观锁,乐观锁竟然如此简单-LMLPHP

    //测试乐观锁失败
@Test
public void testOptimisticlocker2(){ //线程1
//1.查询用户信息
Air air1 = airMapper.selectById(1L);
//2.修改用户信息
air1.setPm25(999);
air1.setPm10(1000); //模拟另一个线程执行了插队操作 //1.查询用户信息
Air air2 = airMapper.selectById(1L);
//2.修改用户信息
air2.setPm25(4555);
air2.setPm10(6666);
//3.执行更新操作
airMapper.updateById(air2);
airMapper.updateById(air1);
}
05-26 08:11