追根溯源,有点意思,关于MySQL更新“丢失”问题

博客探讨了一个在SpringBoot和MyBatis框架下,使用MySQL数据库时遇到的更新“丢失”问题。问题源于事务隔离级别和执行顺序,分析了MyBatis执行流程和MySQL的SQL执行过程,最终确定为事务隔离性导致。提出了Thread.sleep休眠、使用Spring事务管理和定时任务补偿处理三种解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

人生苦短,不如养狗

一、问题现场

趁着这几天过节,复盘了一下去年的一些历史遗留问题,其中有这样一个关于数据库的小问题让我忍不住翻出来又回味了一下,下面就让我们一起品味品味。

首先,先来看下问题现场,操作数据库的执行流程如下图:   

追根溯源,有点意思,关于MySQL更新“丢失”问题

 

这里对原有的业务逻辑进行简化,简化后的代码实现如下:

public void finishSubTask(SubTask subTask){
  // 进行子任务状态更新
  subTaskService.updateFinish(subTask);
  // 根据主任务id查询正在运行中的任务
  int runningSubTaskNum = subTaskService.countRunning(subTask.getTaskId);
  // 如果当前运行中任务为空,则终止主任务
  if (runningSubTaskNum == 0) {
    taskService.updateFinish(subTask.getTaskId);
  }
}

乍一看好像逻辑和代码没有什么问题,但是在实际运行过程中有时会出现查询语句查出来的结果集是更新前的结果集,就好像更新没有生效或者“丢失”了,导致没有成功将对应的主任务终止。

二、追根溯源

在开始查案之前先说一下环境情况,MySQL版本为5.6(阿里云高可用版本,即一主一备,事务隔离级别为读已

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值