mysql事物隔离级别Read Committed(读取已提交)、Repeatable Read(可重读)的区别演示

mysql有四种隔离级别
Read Uncommitted(读取未提交)
       在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少。读取未提交的数据,也被称之为脏读(Dirty Read)。


Read Committed(读取已提交)
       这是大多数数据库系统的默认隔离级别(但不是MySQL默认的)。它满足了隔离的简单定义:一个事务只能看见已经提交事务所做的改变。这种隔离级别 也支持所谓的不可重复读(Nonrepeatable Read),因为同一事务的其他实例在该实例处理其间可能会有新的commit,所以同一select可能返回不同结果。


Repeatable Read(可重读)
       这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。


Serializable(可串行化) 
       这是最高的隔离级别,它通过强制事务排序,使之不可能相互冲突,从而解决幻读问题。简言之,它是在每个读的数据行上加上共享锁。在这个级别,可能导致大量的超时现象和锁竞争。

本文主要演示Read Committed(读取已提交)和Repeatable Read(可重读)的区别

先创建一张表t

CREATE TABLE `t` (
  `id` int(11) NOT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO `t`(`id`) VALUES (1);

再附上两份sql代码演示

mysql事物隔离级别Read Committed(读取已提交)、Repeatable Read(可重读)的区别演示_第1张图片

# 1  查看表中的数据
SELECT * FROM t;

# 2 mysql默认事物隔离级别是可重复读
SHOW VARIABLES LIKE '%tx_isolation%';

# 3 开始事物,并读取表中的数据
BEGIN;
SELECT * FROM t;

#执行另一个标签中的步骤4

# 5 此时不能读取到步骤4插入的数据(跟上一条sql语句的查询结果一样)
SELECT * FROM t;

# 6
COMMIT;

# 7 事物后提交,能读取到步骤4插入的数据了
SELECT * FROM t;


# 8 将事物隔离级别改成读已提交
SET tx_isolation='read-committed';
SHOW VARIABLES LIKE '%tx_isolation%';

# 9
BEGIN;
SELECT * FROM t;

#执行另一个标签也中的步骤10

# 11 此时能读取到步骤10插入的数据。同一个事物中读取两次,两次的结果可能不一样
SELECT * FROM t;

# 12
COMMIT;

# 13 还原事物隔离级别
SET tx_isolation='REPEATABLE-READ';
SHOW VARIABLES LIKE '%tx_isolation%';

# 4
BEGIN;
INSERT INTO t(id) VALUE(2);
COMMIT;

# 10
BEGIN;
INSERT INTO t(id) VALUE(3);
COMMIT;

在事物隔离级别为默认的可重复读时。步骤3、步骤5在已经begin,但未commit的同一事物中。步骤5无法读取步骤4插入的数据。

改变事物级别为读已提交,步骤9、步骤11在已经begin,但未commit的同一事物中。步骤11能读取步骤10插入的数据。

 

你可能感兴趣的:(mysql)