事务的并发问题

  1. 脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据
  2. 不可重复读:事务A多次读取同一数据,事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果不一致。
  3. 幻读:A事务读取了B事务已经提交的新增数据。注意和不可重复读的区别,这里是新增,不可重复读是更改(或删除)。select某记录是否存在,不存在,准备插入此记录,但执行 insert 时发现此记录已存在,无法插入,此时就发生了幻读。

MySQL如何实现避免幻读

  • 在快照读读情况下,MySQL通过MVCC来避免幻读。
  • 在当前读读情况下,MySQL通过next-key来避免幻读

什么是MVCC

MVCC全称是多版本并发控制的简称(multi version concurrent control)。MySQL把每个操作都定义成一个事务,每开启一个事务,系统的事务版本号自动递增。每行记录都有两个隐藏列:创建版本号和删除版本号

MVCC多版本并发控制是MySQL中基于乐观锁理论实现隔离级别的方式,用于读已提交和可重复读取隔离级别的实现。

在MySQL中,会在表中每一条数据后面添加两个字段:最近修改该行数据的事务ID,指向该行(undolog表中)回滚段的指针。

Read View判断行的可见性,创建一个新事务时,copy一份当前系统中的活跃事务列表。意思是,当前不应该被本事务看到的其他事务id列表。已提交读隔离级别下的事务在每次查询的开始都会生成一个独立的ReadView,而可重复读隔离级别则在第一次读的时候生成一个ReadView,之后的读都复用之前的ReadView。

  • select:事务每次只能读到创建版本号小于等于此次系统版本号的记录,同时行的删除版本号不存在或者大于当前事务的版本号。

  • update:插入一条新记录,并把当前系统版本号作为行记录的版本号,同时保存当前系统版本号到原有的行作为删除版本号。

  • delete:把当前系统版本号作为行记录的删除版本号

  • insert:把当前系统版本号作为行记录的版本号

什么是next-key锁

InnoDB 采用 Next-Key Lock 解决幻读问题。

insert into test(xid) values (1), (3), (5), (8), (11)

在这条语句执行后,由于xid上是有索引的,该算法总是会去锁住索引记录
现在,该索引可能被锁住的范围如下:(-∞, 1], (1, 3], (3, 5], (5, 8], (8, 11], (11, +∞)。

select * from test where id = 8 for update

这条语句执行后会锁住的范围:(5, 8], (8, 11]。
除了锁住8所在的范围,还会锁住下一个范围,所谓Next-Key。

MySQL如何避免幻读相关推荐

  1. mysql 什么是幻读_Mysql中的幻读(一)

    什么是幻读 幻读表示的是在一个事物里面 同一个select语句,前后两次查询出来的结果是不相同的,需要注意的一点是,在InnoDB里面,幻读跟事物的隔离级别有关,更加准确的说是跟一个事物的快照和当前读 ...

  2. mysql数据库出现幻读,MySQL 幻读怎样处理?_数据库

    MySQL 幻读怎样处理? 1.MVCC快照,将历史数据存一份快照,在其事件增添与删除数据时,保证当前事件来说是不可见的: 多半数据库都完成了多版本并发掌握,而且都是靠保留数据快照来完成的. 以 In ...

  3. mysql实战20 | 幻读是什么,幻读有什么问题?

    在上一篇文章最后,我给你留了一个关于加锁规则的问题.今天,我们就从这个问题说起吧. 为了便于说明问题,这一篇文章,我们就先使用一个小一点儿的表.建表和初始化语句如下(为了便于本期的例子说明,我把上篇文 ...

  4. mySql 脏读,幻读,不可重复度与事务隔离级别

    mysql有3种并发问题 脏读 读到未提交的数据 A事务 B事务 开启事务 查询结果100 开启事务 更新到150,未提交 查询结果150 回滚 查询结果100 A事务查询到了B事务未提交的内容.这种 ...

  5. mysql脏读,幻读,不可重复读以及间隙所解决幻读

    1.数据脏读 事务a修改了某条数据,然后事务b读取了事务a修改的该条数据,然后事务a由于某些原因,事务a回滚了,这样事务b读到的数据就和回滚的数据不同了,这时事务b读取的数据就是脏数据.概况一句话就是 ...

  6. mysql java 解决幻读_MySQL 是如何解决幻读的

    MySQL 是如何解决幻读的 一.什么是幻读 在一次事务里面,多次查询之后,结果集的个数不一致的情况叫做幻读. 而多出来或者少的哪一行被叫做 幻行 二.为什么要解决幻读 在高并发数据库系统中,需要保证 ...

  7. mysql 什么是幻读_何为幻读?MySQL又是如何解决幻读的?

    一.什么是幻读 在一次事务里面,多次查询之后,查询的结果集的个数不一致的情况叫做幻读.而多出来或者少的哪一行被叫做 幻行 二.为什么要解决幻读 在高并发数据库系统中,需要保证事务与事务之间的隔离性,还 ...

  8. mysql rr解决幻读吗_mysql rr隔离级别解决幻读了吗

    以下内容全部基于innodb. 虽然下面有很多概念很浅显,但还是要解释一下 什么是幻读? 当一个事务在多次查询中,发现了一行不是在当前事务中添加的数据.出现这种问题就叫做幻读. 关于四种隔离级别 未提 ...

  9. mysql 并没有幻读_MySQL默认隔离级别REPEATABLE-READ并没有解决幻读问题

    刷脉脉,发现一个帖子讨论幻读问题: https://maimai.cn/web/gossip_detail?src=app&webid=eyJhbGciOiJIUzI1NiIsInR5cCI6 ...

  10. 五分钟了解Mysql脏读、幻读、不可重复读、mvcc

    点击上方关注 "终端研发部" 设为"星标",和你一起掌握更多数据库知识 首先对多事务并发的问题的思考 对 innodb引擎执行流程 和 buffer pool ...

最新文章

  1. Java 程序员薪资这么高,取决于什么?
  2. v7000更换电池步骤_v7000 gen1 电池更换问题
  3. MySQL中如何查询数据(上)
  4. Python爬取天气信息并定时发送给微信好友(异地恋神器)!!
  5. 51Testing第二十一期软件测试免费沙龙开始报名(上海)
  6. springboot 禁用 cookie / chrome 禁用 cookie
  7. Amazon Aurora:高吞吐量云原生关系数据库的设计考虑
  8. mysql之group_concat函数
  9. 今年圣诞,麋鹿第一次请假
  10. Linux环境下Redis安装配置步骤
  11. 软件测试学生管理系统课程设计,软件测试课程设计-ERP进销存管理系统(1)
  12. Lua1.0 代码分析 table.c
  13. CC2530和8051(51单片机)的关系
  14. HDUOJ 6555 The Fool
  15. 微信小程序day01
  16. 数据库主键到底是用自增长(INT)好还是UUID好?
  17. 微信小程序商城购物车页 二维数组怎么做
  18. shiro for example: not eligible for auto-proxying
  19. lifi与wifi的论文_与WiFi相比 LiFi具有哪些优势?
  20. kong网关安装与启动

热门文章

  1. matlab对图片裁剪处理
  2. java4android 听课笔记_Java4Android 课程笔记
  3. 计算机有很多的优点英语,电脑的优点和缺点英文作文
  4. 图数据和知识图谱,数字化转型的新引擎星环科技星环科技
  5. 在北京租房 舒舍的租客素质怎么样?
  6. linux虚拟内存满了怎么办,解决linux虚拟内存不够用的方法
  7. mysql analyze_MySQL 案例:analyze,慢查询,与查询无响应
  8. tidb-analyze
  9. 400企业智能服务器,全球领先的企业级服务器、存储、融合系统及解决方案-H3C与HPE...
  10. 5G无线技术基础自学系列 | 移动通信网络的架构