mysql事务隔离级别
SQL标准定义了4种隔离级别,
低级别的隔离级别一般支持更高的并发处理,并拥有更低的系统开销
但是低级别的隔离级别,会让各级别之间干扰会更大一些
事务隔离级别有四种
1.read Uncommitted(读取未提交内容)
(1)首先,修改隔离级别
set tx_isolation='READ-UNCOMMITTED';
select @@tx_isolation;
(2)事务A:
create table abc (name char(20),nianling int(3));
insert into abc values ('a',20);
insert into abc values ('b',18);
启动一个事务
begin;
select * from abc;
+------+----------+
| name | nianling |
+------+----------+
| a | 20 |
| b | 18 |
+------+----------+
(3)事务B 我们在开启一个xshell 登录到数据库后,在开启一个事务,执行完事务后, 不提交
mysql> begin;
mysql> select * from abc;
+------+----------+
| name | nianling |
+------+----------+
| a | 20 |
| b | 18 |
+------+----------+
mysql> update abc set nianling=25 where name='a';
我们更改abc的内容,但是不提交
(4)在事务A上查看事务B 的更改。我们是能看到事务B的内容的。
mysql> select * from abc;
+------+----------+
| name | nianling |
+------+----------+
| a | 25 |
| b | 18 |
+------+----------+
即使在事务B上回滚,在A上也可以B上回滚后的内容。
即使B提交了事务,A事务也可以看到提交后的内容。
read Committed(读取提交内容)
repeatable read(可重读)
serializable(可串行化)
这是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。不过理论上,这会导致另一个棘手的问题:幻读 (Phantom Read)。简单的说,幻读指当用户读取某一范围的数据行时,另一个事务又在该范围内插入了新行,当用户再读取该范围的数据行时,会发现有新的“幻影” 行。InnoDB和Falcon存储引擎通过多版本并发控制(MVCC,Multiversion Concurrency Control)机制解决了该问题。