当前位置: 首页 > news >正文

MySQL的REPEATABLE READ事务隔离级别

本文隔离级别:

T1内读T2的update数据

首先开两个事务(左二)

事务1修改成李四,提交

事务2再读还是张三,也就是说,记录的数据从事务开始时一直到结束,读的都是同一个版本,读不到T2未提交的此条记录修改,也读不到T2已提交的修改

T1修改数据未提交,T2修改数据互斥

更新操作会发生行修改锁互斥行为,只能等其他事务提交事务其他事务才能再做更新。

REPEATABLE READ是否有幻读

正常情况下,幻读是T2新增了满足T1查询条件的记录

select * from test_tx where id>=1;

T1事务时,T2突然插入两条符合的记录,T1再次查询,也不会查询到(间隙锁)

但是,如果下面顺序情况发生了就会有问题:

幻读的经典定义是:在同一个事务中,两次执行相同的查询,结果出现了“新幻影记录”,即第二次查询返回了第一次查询范围之外的新数据。

T1 执行了 UPDATE 操作,而这个 UPDATE 触发了 范围检查(间隙锁),它并非普通的查询,所以严格来说,不是幻读,而是 更新范围重新评估 的结果。

http://www.lryc.cn/news/508668.html

相关文章:

  • sqoop的参数有哪些?
  • 动态规划<四> 回文串问题(含对应LeetcodeOJ题)
  • 跨模态知识迁移:基于预训练语言模型的时序数据建模
  • 重温设计模式--职责链模式
  • git冲突解决
  • Java学习笔记(14)--面向对象编程
  • 《Swift 字面量》
  • 数据库 SQL 常用语句全解析
  • SQLite 命令
  • 本地如何启动casdoor
  • 目标检测-R-CNN
  • 【持续更新】Github实用命令
  • docker 容器的基本使用
  • css让按钮放在最右侧
  • 8K+Red+Raw+ProRes422分享5个影视级视频素材网站
  • Linux网络——UDP的运用
  • 项目亮点案例
  • Retrofit源码分析:动态代理获取Api接口实例,解析注解生成request,线程切换
  • 范德蒙矩阵(Vandermonde 矩阵)简介:意义、用途及编程应用
  • 【中标麒麟服务器操作系统实例分享】java应用DNS解析异常分析及处理
  • 网安瞭望台第17期:Rockstar 2FA 故障催生 FlowerStorm 钓鱼即服务扩张现象剖析
  • 玩转OCR | 探索腾讯云智能结构化识别新境界
  • idea2024创建JavaWeb项目以及配置Tomcat详解
  • 外连接转AntiJoin的应用场景与限制条件 | OceanBase SQL 查询改写系列
  • 华为实训课笔记 2024 1223-1224
  • MySQL超详细安装配置教程(亲测有效)
  • MySQL 8.0:explain analyze 分析 SQL 执行过程
  • 信管通低代码信息管理系统应用平台
  • git推送本地仓库到远程(Gitee)
  • 【C++语言】多态