InnoDB 事务隔离级别(Mysql篇)

前言:
Mysql支持MyISAM和InnoDB两种存储引擎,区别在此就不详细说明。此篇是讲述事务,所以切记自己的table是InnDB。此处大坑!

在Mysql InnoDB 中,事务主要有四种隔离级别

  • Read uncommitted (未提交读)
  • Read committed (已提交读)
  • Repeatable read (可重复读)
  • Serializable (可串行化)

在理解四种隔离级别之前,我们需要先了解另外三个名词:

  1. 脏读
  2. 不可重复读
  3. 幻读
脏读
另一个事务修改了数据,但尚未提交,而本事务中的SELECT会读到这些未被提交的数据。
不重复读
解决了脏读后,会遇到,同一个事务执行过程中,另外一个事务提交了新数据,因此本事务先后两次读到的数据结果会不一致。
幻读
解决了不重复读,保证了同一个事务里,查询的结果都是事务开始时的状态(一致性)。但是,如果另一个事务同时提交了新数据,本事务再更新时,就会“惊奇的”发现了这些新数据,貌似之前读到的数据是“鬼影”一样的幻觉。

下面我们就直接来通过实验来看,Mysql Innodb中,不同的事务隔离级别,会出现怎么样的结果。

首先我们开启两个终端,查询当前MySQL的默认隔离级别:

SELECT @@global.tx_isolation; //查询全局事务
SELECT @@session.tx_isolation; //查询当前会话事务

这里写图片描述
可以看到,默认的隔离级别是:REPEATABLE-READ

实验Read uncommitted

我们

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值