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)机制解决了该问题。

posted @ 2017-03-11 15:40  借风拥你  阅读(134)  评论(0编辑  收藏  举报