Mysql的select for update理解

背景

一条数据不能同时被两个或者多个线程修改。保证数据的有效性。比如下订单后,扣库存数量就需要这样的保证。

过程
  • 数据库中数据
    在这里插入图片描述

  • 测试方法1:testForUpdate1
    在这里插入图片描述
    分析:代码在if判断处,打上断点。

  • 测试方式2:testForUpdate2
    在这里插入图片描述

  • 测试过程描述
    先跑测试方法1,一直卡在断点处。这个时候直接执行测试方法2。

  • 测试结果
    在这里插入图片描述

  • 测试结果分析
    由于测试方法1先把id为27的数据上锁。测试方法2能够读到数据,但是不能修改id为27的数据。

小结

记录对一个小知识的理解过程。select for update。 这是一个悲观锁。它解决了什么问题呢?并发问题。那还有其他方式解决吗?可以使用乐观锁的方式。如果是集群或者分布式环境,也可以尝试使用分布式锁来解决并发问题。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值