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

到底什么才是幻读?

💗推荐阅读文章💗

  • 🌸JavaSE系列🌸👉1️⃣《JavaSE系列教程》
  • 🌺MySQL系列🌺👉2️⃣《MySQL系列教程》
  • 🍀JavaWeb系列🍀👉3️⃣《JavaWeb系列教程》
  • 🌻SSM框架系列🌻👉4️⃣《SSM框架系列教程》

🎉本博客知识点收录于🎉👉🚀《MySQL系列教程》🚀—>✈️12【事务的隔离级别】✈️

文章目录

    • 2.7 幻读
      • 2.7.1 幻读解决情况1):
      • 2.7.2 幻读解决情况2):
      • 2.7.3 幻读问题出现情况1):
      • 2.7.3 特殊情况:

2.7 幻读

概念:一次事务多次读取到的条数不一致而引发的问题;

在InnoDB(暂时理解是MySQL)中幻读在很多地方都得到了解决,但在一些特殊的情况下,还是会引发幻读问题;

为什么有的情况下能解决,有的情况下解决不了?因为一次事务多次读取到的条数不一致会导致有很多情况发生!

2.7.1 幻读解决情况1):

还原数据:

update account set money=1000;-- 设置隔离级别为repeatable read
set global transaction isolation level repeatable read;

记得重启客户端

session-01session-02
begin;
begin;
select * from account;
insert into account values(3,‘c’,1000);
commit;
select * from account;

观察变化:

在这里插入图片描述

幻读问题得到解决

2.7.2 幻读解决情况2):

还原数据

案例:

session-01session-02
begin;
begin;
select sum(money) from account;
insert into account values(3,‘c’,1000);
commit;
select sum(money) from account;

观察变化:

在这里插入图片描述

2.7.3 幻读问题出现情况1):

还原数据

  • 案例:
session-01session-02
begin;
begin;
select count(id) from account;
insert into account values(3,‘c’,1000);
commit;
select count(id) from account;
update account set money=0;
select count(id) from account;

观察变化:

在这里插入图片描述

2.7.3 特殊情况:

还原数据

  • 案例:
session-01session-02
begin;
begin;
select * from account;
select * from account;
insert into account values(3,“c”,1000);
commit;
select * from account;
insert into account values(3,“c”,1000);

观察变化:

在这里插入图片描述

Tips:严格意义来说,上述案例是MySQL的快照机制导致的,不能算幻读;关于幻读我们理解概念就行,即:两次读取到的条数不一致!这就是幻读

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

相关文章:

  • RPC重试机制和控制方案
  • 【无标题】动态给结构体赋值
  • centos7 soft raid每周自动同步的问题
  • 嵌入式Linux内核代码风格
  • Andorid:关于Binder几个面试问题
  • 【剑指Offer-Java】包含min函数的栈?
  • 红队APT——邮件钓鱼攻击SwaksOffice漏洞RLO隐藏压缩释放
  • 【Java|基础篇】超详细讲解运算符
  • Promise-异步回调
  • 【设计模式之美 设计原则与思想:设计原则】21 | 理论七:重复的代码就一定违背DRY吗?如何提高代码的复用性?
  • 深度学习 | 入个Pytorch的小门
  • 应用上云指导
  • 进程概念~
  • 三天吃透Java基础八股文
  • YOLOv8训练自己的数据集(超详细)
  • 【洛谷 P1088】[NOIP2004 普及组] 火星人 题解(全排列+向量)
  • 基于混合蛙跳算法优化SVM的滚动轴承故障诊断python实现
  • 如何让AI帮你干活-娱乐(2)
  • 文件异步多备常用方案
  • java面试八股文之------Redis夺命连环25问
  • 【数据结构】AVL平衡二叉树底层原理以及二叉树的演进之多叉树
  • K8S篇-安装nfs插件
  • xmu 离散数学 卢杨班作业详解【4-7章】
  • 多重背包问题中的二进制状态压缩
  • 汇编语言程序设计(四)之汇编指令
  • Vant2 源码分析之 vant-sticky
  • 【自然语言处理】【大模型】大语言模型BLOOM推理工具测试
  • 云桌面技术初识:VDI,IDV,VOI,RDS
  • 基于本地centos构建gdal2.4.4镜像
  • 生产环境线程问题排查