• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySql学习笔记之事务隔离级别详解

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论

背景

说的事务,大家应该都不陌生,开发用到 MySql 数据库的时候,通常会用到事务。其中比较经典的例子就是转账,比如你要给小明转 50 块钱,而此时你的银行卡也就只有 50 块钱。

对于转账过程在代码程序里会有一系列的操作,比如查询账户余额、余额加减、更新余额等,这些操作必须保证是一起处理的,不然等程序查完之后,如果账号 50 块钱还在,然后再给另外一个朋友转账,如果银行也处理的话,没有保证整个流程数据一致性的话,这不就乱套了吗?这时就要用到“事务”了。

事务介绍

简单来说,事务就是要保证一组数据库操作,要么全部执行成功,要么全部都失败。在 MySQL 中,事务支持是在引擎层(InnoDB)实现的。我们知道,MySQL 是一个支持多引擎的系统,但并不是所有的引擎都支持事务。比如 MySQL 原生的 MyISAM 引擎就不支持事务,这也是 MyISAM 被 InnoDB 取代的重要原因之一。

在这篇文章里,将会以 InnoDB 为例,说说 MySQL 在事务支持方面的一些实现,并基于原理给出相应的实践建议,通过这些说明,可以加深对 MySQL 事务原理本文来源gaodai$ma#com搞$代*码6网的理解。

事务的隔离级别

提到事务,你肯定会想到 ACID(Atomicity、Consistency、Isolation、Durability,即原子性、一致性、隔离性、持久性),下面我们就来说说其中 I,也就是“隔离性”。

当数据库上有多个事务同时执行的时候,就可能出现脏读(dirty read)、不可重复读(non-repeatable read)、幻读(phantom read)的问题,为了解决这些问题,就有了“隔离级别”的概念。

在谈隔离级别之前,你首先要知道,你隔离得越严实,效率就会越低。因此很多时候,我们都要在二者之间寻找一个平衡点。SQL 标准的事务隔离级别包括:读未提交(readuncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(serializable )。下面逐一为你解释:

  • 读未提交是指,一个事务还没提交时,它做的变更就能被别的事务看到。
  • 读提交是指,一个事务提交之后,它做的变更才会被其他事务看到。
  • 可重复读是指,一个事务执行过程中看到的数据,总是跟这个事务在启动时看到的数据是一致的。当然在可重复读隔离级别下,未提交变更对其他事务也是不可见的。
  • 串行化,顾名思义是对于同一行记录,“写”会加“写锁”,“读”会加“读锁”。当出现读写锁冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行。

其中“读提交”和“可重复读”比较难理解,所以打算用一个例子说明这几种隔离级别。假设数据表 t_student 中只有一列,其中一行的值为 21,下面是按照时间顺序执行两个事务的行为。

mysql> create table t_student(age int) engine=InnoDB;
mysql> insert into t_student(age) values(21);

在不同的隔离级别下,事务 A 会有哪些不同的返回结果,也就是图中 V1、V2、V3 的返回值分别是什么。若隔离级别是“读未提交”, 则 V1 的值就是 22。这时候事务 B 虽然还没有提交,但是结果对于 A 来说是可见的。因此,V2、V3 也都是 22。

若隔离级别是“读提交”,则 V1 是 21,V2 的值是 22。事务 B 的更新在提交后对 A 才是可见的。所以, V3 的值也是 22。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySql学习笔记之事务隔离级别详解

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址