呢喃闪烁 2020-03-09 17:55 采纳率: 16.7%
浏览 518

Spring Boot设置了数据库隔离级别但是无效。

我在学习如何处理高并发,用的是Mysql。学习使用数据库隔离级别,在配置文件里设置了如下属性:

spring.datasource.tomcat.default-transaction-isolation=4


但还是出现问题了,我原本库存设置的1000,抢购时会先看库存数是否大于0,如果为true则库存减1,结果一波抢购操作直接导致库存为-4。

就算说哪里出问题没设设置成功,Mysql默认隔离级别也是可重复读啊。为什么还是不能保证高并发的处理呢?

之后我在sql语句中加了悲观锁,结果正常。我就纳闷了,难道说隔离级别没有用吗?按照我理解的可重复读,一位客户在获取库存后,其他客户应该不能再获取了啊。

  • 写回答

1条回答 默认 最新

  • 关注
    评论

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!