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

mysql可重复读不能解决幻读吗?

1、可重复读和幻读的概念

1.1、可重复读

       可重复读是数据库的四个隔离级别之一,可重复读可以保证在一个事物之内读取到的数据永远是相同的(通过mvcc表快照实现的),哪怕这期间有其它事务对数据做了修改,也不会影响当前事务的查询。

1.2、幻读

      网上有不少博客说:幻读是一个事物内多次查询得到的数据结果不一样。比如说select (1)这种查询,如果有其它事务增加或删除了数据,会影响到当前事务的select (1)。这种说法是错误的,因为可重复读隔离级别下,这种情况就不会出现,后面会有实际操作。
      我认为的幻读是一个事务内,比如执行查询select * from test where id = 3 没有查出来数据,然后接着执行insert操作INSERT INTO test (id) values (3),可能会因为其它事务先一步插入了id为3的数据,导致当前事务插入数据失败。这种情况是可能会出现的,可重复读解决不了这种问题。

2、实操

      以此表为例,表里只有主键id字段,只有两条数据。
在这里插入图片描述
      开启事务,查询id为3的数据
在这里插入图片描述
      会查询不到,再开启一个事务,插入id为3的数据。
在这里插入图片描述
      操作成功,表里已经有了id为3的数据了
在这里插入图片描述
      但是之前的第一个事务由于是在插入id为3的事务之前开启的,所以第一个事务是查询不到id为3的数据的。
在这里插入图片描述
在这里插入图片描述
      下面复刻幻读,给第一个事务也执行插入id为3的数据。
在这里插入图片描述
      可以看到,报错了。因为id为3的数据已经被其他事务插入了。这就是我理解的可重复读无法解决的幻读。
      这也是我面试喜欢问的一个问题,在一个事务内对同一个查询执行两次,查询出来的结果肯定会一样吗?我想现在大家心里应该有答案了吧。


http://www.kler.cn/a/302498.html

相关文章:

  • 基于Java Springboot快递物流管理系统
  • 【学习日记】notebook添加JAVA支持
  • 必修 -- 常用笔试题
  • 重构开发之道,Blackbox.AI为技术注入智能新动力
  • [DEBUG] 服务器 CORS 已经允许所有源,仍然有 304 的跨域问题
  • 微澜:用 OceanBase 搭建基于知识图谱的实时资讯流的应用实践
  • linux————根据端口查找运行目录的三种方法
  • STM32内部闪存FLASH(内部ROM)、IAP
  • 信息安全工程师题
  • ASR(自动语音识别)识别文本效果的打分总结
  • 用Cri-O,Sealos CLI,Kubeadm方式部署K8s高可用集群
  • 【docker】了解什么是Docker
  • 欧洲麻花钻市场主要企业市场占有率及排名
  • Framework | 在Android中运行时获取顶层Activity并处理业务逻辑
  • 【测试】——自动化测试入门(Selenium环境搭建)
  • Golang | Leetcode Golang题解之第395题至少有K个重复字符的最长子串
  • IPC$漏洞多位密码爆破方法
  • 揭开Facebook AI的神秘面纱:如何利用人工智能提升社交体验
  • Java笔试面试题AI答之单元测试JUnit(4)
  • 亚信安全出席第五届国际反病毒大会 探究AI现代网络勒索治理
  • SprinBoot+Vue爱老助老服务平台的设计与实现
  • JAVAEE初阶第六节——网络编程套接字
  • 通信工程学习:什么是SLF签约数据定位功能
  • 携手科大讯飞丨云衔科技为企业提供全栈AI技术解决方案
  • yolov8学习笔记
  • 深入理解Java中的Lambda表达式