文章目录

  • 1. 脏读(dirty read)
    • 脏读是指事务读取到其他事务未提交的数据
  • 2. 不可重复读(non-repeatable read)
    • 不可重复读是指在同一次事务中前后查询不一致的问题
  • 3. 幻读(phantom read)
    • 幻读是一次事务中前后数据量发生变化,用户产生不可预料的问题
  • 4. 不可重复读和幻读的比较
  • 5. 总结
  • 6. 解决方法

1. 脏读(dirty read)

脏读是指事务读取到其他事务未提交的数据

例如:有事务A、B和一条记录:id为1,name为张三

B首先进行更新操作,将name的值由张三改为张老三,但还未提交事务

begin;
update stu set name = '张老三' where id = 1

然后A进行查询操作,查询姓名为张老三

select name from stu where id = 1

然后B由于某种原因被回滚,name自然从张老三恢复到了张三

A就会出现一个问题,读取的是张老三,但数据库中实际存储的是张三,我到底是用哪一个呢?

这就是脏读,事务A读取到事务B未提交的数据

脏读是我们在整个数据库操作中最普遍的一个现象,但是在日常开发中我们几乎不会遇到脏读,原因以后说

看图更容易理解

2. 不可重复读(non-repeatable read)

不可重复读是指在同一次事务中前后查询不一致的问题

例如:

A先查询了一条记录,name为张三

select name from stu where id = 1

然后B执行了更新,并且提交

begin;
update stu set name = '张老三' where id = 1;
commit

A再次按相同条件查询该记录,name为张老三

select name from stu where id = 1

A就会出现一个问题,同样的查询语句,两次的执行结果却不一致(不重复)

第二次查询得到的name应该还是预期的张三,因为很明确,A并没有对name进行修改,但是在并发环境下,假如两条select语句间有另外一个事务对name执行了update操作并提交了,把张三的名字改为了张老三,A再次执行同样查询导致name由张三变为张老三

A就有意见了,我明明没有对name进行修改,可是为什么后来变成张老三了?谁改我数据了?

这就是不可重复读:同一次事务中前后查询不一致

它会让我们的程序运行变得不可预期、不可控

看图更容易理解

3. 幻读(phantom read)

幻读是一次事务中前后数据量发生变化,用户产生不可预料的问题

分为并发删除和并发插入的情况

1 并发插入

A先查询了一条记录,name为张三

select name from stu where id = 1

B插入了一条数据,name为李四

insert into stu(name) values('李四')

当A再次按相同条件查询

select name from stu where id = 1

结果多了一条李四的记录,刚才明明只有一条记录,怎么多出来一条?好像出现了幻觉

2 并发删除

将上面的插入操作换成删除操作,B删除了张三的记录

delete from stu where id = 1

结果A会发现张三的记录神秘的消失了,明明刚才还有的,怎么又没了,再次出现了幻觉

这就是幻读,看图更容易理解

4. 不可重复读和幻读的比较

1 幻读和不可重复读都是读取了另一条已经提交的事务(这点就脏读不同),所不同的是不可重复读查询的都是同一个数据项,而幻读针对的是一批数据整体(比如数据的个数)。
2 不可重复读的重点是修改,幻读的重点在于插入或者删除
3 但如果从控制的角度来看, 两者的区别就比较大
对于前者, 只需要锁住满足条件的记录
对于后者, 要锁住满足条件及其相近的记录

5. 总结

脏读是指事务读取到其他事务正在处理的未提交数据

不可重复读指在并发更新时,另一个事务前后执行相同条件的查询得到的数据不一致

幻读指并发插入、删除时,另一个事务前后执行相同条件的查询得到的数据不一致

6. 解决方法

如何解决以上问题,事务的隔离级别就派上用场了

禁止写时读,避免了“脏读”,对应隔离级别read committed。

禁止读时写,避免了“不可重复读”,对应隔离级别repeatable read。

而为了避免“幻读”,干脆把整个表给锁住了,只能是serialize了。

隔离级别越高,并行度越低,付出的代价越大。

MySQL理论:脏读、不可重复读、幻读相关推荐

  1. mysql 脏读 不可重复读 幻读_mysql事务隔离级别/脏读/不可重复读/幻读详解

    一.四种事务隔离级别 1.1read uncommitted 读未提交 即:事务A可以读取到事务B已修改但未提交的数据. 除非是文章阅读量,每次+1这种无关痛痒的场景,一般业务系统没有人会使用该事务隔 ...

  2. 脏读,不可重复读,幻读区别

    脏读 脏读又称无效数据读出.一个事务读取另外一个事务还没有提交的数据叫脏读. 例如:事务T1修改了一行数据,但是还没有提交,这时候事务T2读取了被事务T1修改后的数据,之后事务T1因为某种原因Roll ...

  3. mysql不可重复读和重复读_MySql隔离级别:RU / RC / RR / S + 脏读 / 不可重复读 / 幻读 / 可重复读...

    MySQL 事务 本文所说的 MySQL 事务都是指在 InnoDB 引擎下,MyISAM 引擎是不支持事务的. 数据库事务指的是一组数据操作,事务内的操作要么就是全部成功,要么就是全部失败,什么都不 ...

  4. oracle 脏读,脏读 不可重复读 幻读

    序言 脏读.不可重复读.幻读这几个概念开始接触和学习的时候是在大学学习数据库系统的时候,那时候对这几个专业名词的理解停留在概念文字上,并没有真正使用过实践中,最近工作中涉及到这几个概念方面的知识,就来 ...

  5. 脏读,不可重复读,幻读区别和避免

    在了解脏读,不可重复度,幻读之前,首先要明白这三种情况的出现都是和数据库并发事务有关联的,如果所有的读写都按照队列的形式进行,就不会出现问题. 名词解析和解决方案 脏读 脏读又称无效数据读出(读出了脏 ...

  6. Mysql如何实现隔离级别 - 可重复读和读提交 源码分析

    Abstract 本文会(1) 演示Mysql的两种隔离级别.  (2) 跟着mysql的源代码来看看它是怎么实现这两种隔离级别的. Mysql的隔离级别 当有多个事务并发执行时, 我们需要考虑他们之 ...

  7. MySQL可重复读和读已提交实现原理,深入理解MVCC。

    1.隔离级别 MySQL中隔离级别分为4种,提未交读.读已提交.可重复读.串行化.同时MySQL默认隔离级别为可重复读. 图片 查看MySQL隔离级别 SELECT @@tx_isolation 设置 ...

  8. mysql 可重复读和读提交的区别

    事务的四种隔离级别 未提交读(Read Uncommitted):允许脏读,也就是可能读取到其他会话中未提交事务修改的数据 提交读(Read Committed):只能读取到已经提交的数据.Oracl ...

  9. 三分钟了解MVCC(InnoDB如何实现可重复读和读已提交)

    快照读和当前读 快照读 快照读是指读取数据时不是读取最新版本的数据,而是基于历史版本读取的一个快照信息(mysql读取undo log历史版本) , 快照读可以使普通的SELECT 读取数据时不用对表 ...

  10. MySQL 乱七八糟的可重复读隔离级别实现

    点击上方"芋道源码",选择"置顶公众号" 技术文章第一时间送达! 源码精品专栏 精尽 Dubbo 原理与源码专栏( 已经完成 69+ 篇,预计总共 75+ 篇 ...

最新文章

  1. 【ES6】 let与const详解
  2. Action 相关组件
  3. 5G NGC — NSSF 网络切片选择功能
  4. 中国超细旦丝现状调研及投资前景评估报告2022-2028年版
  5. fiddler修改response header
  6. 学习程序开发的方法,仅供参考吧
  7. Android 自定义环形圆形显示统计数据z
  8. 大学计算机课第二章内容总结,第四周市政系《大学计算机基础》课程总结
  9. debian换源_WSL2安装Debian(Ubuntu)并配置国内apt源
  10. 猜数游戏python_零基础掌握Python入门到实战
  11. Windows核心编程_窗口属性表
  12. Multistage GAN for Fabric Defect Detection 用于织物检测的多级GAN
  13. java不显示图片_java图片显示不出来应该如何解决
  14. mysql ubb html_自动闭合HTML/ubb标签函数
  15. java.lang.ClassNotFoundException问题的解决
  16. 爬虫基础回顾-requests
  17. ps切图(2)——简单工具操作(1)
  18. PDF不能编辑怎么办,如何去掉编辑权限
  19. Spring学习【2】
  20. 2021-你需要知道的前端网络知识-http

热门文章

  1. visio 新建个人模板
  2. Linux文件系统保护最佳实践:Tripwire
  3. java quartz下载_下载、设置和运行Quartz(GUI)图形界面程序----Quartz Web
  4. 机器学习算法之--决策树总结
  5. gre vim linux,OVS搭建GRE隧道和VXLAN
  6. 二级页面全屏html,还是二级网页不能全屏怎么办? 爱问知识人
  7. muse-ui.css_Muse UI:适用于Vuejs 2.0的Material Design UI库
  8. Nginx 动态添加IP黑名单
  9. Hexo的Next主题增加畅言评论
  10. 有声小说配音兼职平台,十大正规配音兼职平台