MySQL之事务隔离级别和MVCC[亲测有效]

MySQL之事务隔离级别和MVCC[亲测有效]事务隔离级别 事务并发可能出现的问题 脏写 事务之间对增删改互相影响 脏读 事务之间读取其他未提交事务的数据 不可重复读 一个事务在多次执行一个select读到的数据前后不相同。因为被别的未提交事务修

MySQL之事务隔离级别和MVCC

事务隔离级别

事务并发可能出现的问题

  • 脏写 事务之间对增删改互相影响
  • 脏读 事务之间读取其他未提交事务的数据
  • 不可重复读 一个事务在多次执行一个select读到的数据前后不相同。因为被别的未提交事务修改,删除数据或数据被更新被当前事务读取到了。
  • 幻读 一个事务在第一次读取正常数据,第二次读取到其他未提交事务的insert记录,导致读取一个不存在的记录。指一次读取读取到了之前未读取到的数据。

事务的4个隔离级别,以及解决的问题

  • READ UNCOMMITTED 未提交读 解决脏写
  • READ COMMITTED提交读 解决脏写、脏读
  • REPEATABLE READ可重复读 解决脏写、脏读、不可重复读
  • SERIALIAZBLE可串行化 解决脏写、脏读、不可重复读、幻读

四个隔离级别和可以解决的问题是SQL专门规定的,但是在Innodb引擎下,在可重复读的隔离级别的下就可以直接解决幻读的问题。

我们可以在启动时指定系统参数修改系统默认的隔离级别,默认为可重复读。

mysql> show variables like "transaction_isolation";
+-----------------------+-----------------+
| Variable_name         | Value           |
+-----------------------+-----------------+
| transaction_isolation | REPEATABLE-READ |
+-----------------------+-----------------+
1 row in set, 1 warning (0.00 sec)

MVCC

版本链

我们在前面就讲过了undo日志,对于每次进行增删改就会产生undo日志,这时每个数据行的roll_pointer就会指向一个undo链表,我们就称其为版本链。我们在提一嘴,因为insert的undo日志在提交后是没有用的,所以在事务提交后insert的undo就会被释放。

可以到前面的文章了解一下undo日志。大概知道undo日志的类型和产生的过程就OK了感觉怎么存储undo日志的那一部分讲得云里雾里https://www.cnblogs.com/duizhangz/p/16333565.html

为什么没用?因为插入并不维护旧值,只是表明一个插入,并不需要存储什么信息。所以在事务提交时直接释放掉。因为事务在回滚时需要由一条insert语句类型的undo进行回滚。

image

这就是上面俩事务生成的版本链。

image

undo链表头存储的就是最新事务更新的记录信息。

ReadView

对于不同的事务隔离级别,我们可以读取的记录数据是不一样的。

  • 对于未提交读的隔离级别来说,我们可以直接读到数据的最新版本。

  • 对于提交读的隔离级别来说,我们需要可以读到的就是已经提交的事务的修改数据。

  • 对于可重复读的隔离级别来说,我们需要可以读到在事务开启前已经提交的事务的数据。

  • 对于串行读的隔离节别来说,Innodb采用加锁的方式来保证串行读。

对于中间两个隔离级别,就需要ReadView这个结构来实现MVCC。以下是ReadView的结构

  • m_ids : 表示在生成ReadView时当前系统中活跃的读写事务ID的列表
  • min_trx_id : 表示在生成ReadView时当前系统中活跃的读写事务ID的最小值即在m_ids中最小的事务ID。
  • max_trx_id : 表示生成ReadView时系统中应该分配给下一个事务的ID。
  • creator_trx_id : 表示生成该ReadView的事务ID。

有了ReadView这个结构,我们在就可以对事务进行控制。

  • 当被访问的记录行的事务ID大于等于max_trx_id,说明当前数据行不可见。
  • 当被访问的记录行的事务ID小于min_trx_id,可以直接获得数据。
  • 当被访问的记录行的事务ID等于creator_trx_id,说明是当前事务修改的记录,可以直接访问。
  • 当被访问的记录行的事务ID大于min_trx_id且小于max_trx_id,我们需要判断一下这个事务ID是不是在m_ids列表中,因为由可能是一个很早的事务很久还执行不介绍,导致中间的事务都结束了,如果在m_ids列表中,说明是活跃的,当前记录行不能访问,否则可以访问数据行。

当前情况在版本链中从头到尾遍历,直到获得到数据。

上面提到的提交读和可重复读,因为是两个隔离级别有区别的,两个隔离级别的实现只要在ReadView的时机上进行把控,就可以实现。

  • 提交读,我们只要保证当前事务的每个语句能读到已经提交的事务的数据。就可以在每个查询数据进行前,事务就会创建一个ReadView。
  • 可重复读,我们只要保证当前事务每个语句能读到事务开启前的数据,就可以在事务第一次读取数据时会创建ReadView,然后整个事务只会使用这个ReadView去判断能读取的数据行。

仔细品一品,一下就可以恍然大悟。

这个MVCC只会在我们使用普通select查询才会生效。

原文地址:https://www.cnblogs.com/duizhangz/archive/2022/06/01/16333589.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/5173.html

(0)
上一篇 2023-05-20
下一篇 2023-05-20

相关推荐

  • Python Dictionary: 储存和访问数据的有力工具

    Python Dictionary: 储存和访问数据的有力工具在Python中,字典(Dictionary)是一种非常有用的数据类型。它允许你快速地储存和访问键值对,并且可以使用各种方法来处理和操作数据。在本篇文章中,我们将会从多个方面对Python字典进行详细的阐述。

    2024-01-31
    100
  • Flink 作业提交流程「建议收藏」

    Flink 作业提交流程「建议收藏」大家好,我是小寒~ 今天给大家带来一篇 flink 作业提交相关的文章。 我们都知道,在开发完一个 flink 应用程序后,打包成 jar 包,然后通过 FLink CLI 或者 Web UI 提交作

    2023-05-25
    132
  • MySQL基础-视图

    MySQL基础-视图视图 定义 : 本质就是一张虚拟表 。从一个或多个表中结合查询出来的结果集, 作用和真实表一样 。可以使用SELECT 语句查询数据,也可以使用INSERT,UPDATE,DELETE 来修改数据。

    2022-12-27
    156
  • 用Python计算100的平方根

    用Python计算100的平方根Python中可以通过调用math模块中的sqrt()函数来计算一个数的平方根。在上面的代码中,我们导入了math模块,并使用sqrt()方法对100进行计算,最终打印出结果为10。

    2024-04-11
    78
  • Labelme安装教程

    Labelme安装教程Labelme是一款图像标注工具,可以用于创建、编辑和标记图像,是深度学习中非常常用的数据集标注工具。本文将介绍如何安装和配置Labelme,以及如何使用它来进行图像标注。

    2024-06-05
    69
  • Python Strip Diagram Template – 优化代码可读性和调试效率的利器

    Python Strip Diagram Template – 优化代码可读性和调试效率的利器Python是一种高级编程语言,广泛应用于各种领域,如Web开发、人工智能、数据分析与科学计算等。在编写代码时,我们不仅要追求程序的功能性,还要注重代码的可读性、可维护性以及调试效率。Python Strip Diagram Template就是一种优化代码可读性和调试效率的利器。

    2024-01-16
    94
  • mysql记录操作记录_记录表

    mysql记录操作记录_记录表概览 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现数据

    2023-02-02
    141
  • MongoDB安装调试

    MongoDB安装调试1:安装 去mongodb的官网http://www.mongodb.org/downloads下载32bit的包 解压后会出现以下文件 在安装的盘C:下建立mongodb文件夹,拷贝bin文件夹到该

    2022-12-16
    142

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注