MySQL InnoDB :事务隔离隔离级别以及对应的问题
2017-05-16 13:54
686 查看
通过锁机制可以实现事务的隔离性要求,使得事务可以并发地工作。但是锁的使用也会带来几种问题:脏读,不可重复读,幻读, 丢失更新。
ANSI SQL隔离级别
1, 脏读 :事务A会读取另外一个事务B尚未提交的数据(Read-Uncommitted)
违反事务的隔离性(isolation)要求
脏数据:事务对缓冲池中的行记录已经修改,但是还没有被提交(uncommitted)。
这种情况会在tx_isolation=READ-UNCOMMITTED的情况下出现。
只要tx_isolation=READ-COMMITTED,就可以避免脏读。
2, 不可重复读 : 事务A读取某一行数据 r = r0, 同时另一个事务B修改 r = r1 ,并且提交,导致事务A读取的数据 r 前后不一致。
违反事务的一致性(consistent)要求
这种情况会在tx_isolation=READ-COMMITTED的情况下出现。
只要tx_isolation=REPEATABLE-READ就可以避免
3,幻读Phantom Read
当事务A读取在某个范围内的记录时,另一个事务B又在该范围内插入了新的数据,当A再次读该范围内的数据时产生了幻行。
这种情况会在tx_isolation=REPEATABLE-READ的时候产生,要避免的话需要设置tx_isolation=Serializable
4,丢失更新
两个事务都对某个数据进行更新操作,但是其中一个被覆盖。这种情况会在tx_isolation=REPEATABLE-READ的情况下出现。
这时候需要设置为tx_isolation=Serializable才可以避免
ANSI SQL隔离级别
隔离级别 | 脏读 | 不可重读 | 幻读 | 加锁读 |
READ-UNCOMMITTED | YES | YES | YES | NO |
RED-COMMITTED | NO | YES | YES | NO |
REPEATABLE-READ | NO | NO | YES | NO |
SERIALIZABLE | NO | NO | NO | YES |
违反事务的隔离性(isolation)要求
脏数据:事务对缓冲池中的行记录已经修改,但是还没有被提交(uncommitted)。
这种情况会在tx_isolation=READ-UNCOMMITTED的情况下出现。
只要tx_isolation=READ-COMMITTED,就可以避免脏读。
事务A | 事务B |
begin; | |
begin; | |
select * from phantom where a=1; (1,1) | |
update phantom set b=100 where a=1; | |
select * from phantom where a=12;(1,100) | |
commit; | |
commit; |
违反事务的一致性(consistent)要求
这种情况会在tx_isolation=READ-COMMITTED的情况下出现。
只要tx_isolation=REPEATABLE-READ就可以避免
事务A | 事务B |
begin; | |
begin; | |
select * from phantom where a=1; (1,1) | |
update phantom set b=100 where a=1; | |
commit; | |
select * from phantom where a=12;(1,100) | |
commit; |
当事务A读取在某个范围内的记录时,另一个事务B又在该范围内插入了新的数据,当A再次读该范围内的数据时产生了幻行。
这种情况会在tx_isolation=REPEATABLE-READ的时候产生,要避免的话需要设置tx_isolation=Serializable
事务A | 事务B |
begin; | |
begin; | |
select * from phantom; (1,1) | |
insert into phantom values(1,2); | |
commit; | |
select * from phantom;(1,1)(1,2) | |
commit; |
两个事务都对某个数据进行更新操作,但是其中一个被覆盖。这种情况会在tx_isolation=REPEATABLE-READ的情况下出现。
这时候需要设置为tx_isolation=Serializable才可以避免
相关文章推荐
- Mysql事务以及四中隔离级别实例2以及InnoDB如何解决当时读的幻读问题
- Mysql的事务和事务的隔离级别,读写引发的安全问题以及解决方案
- MySQL InnoDB事务的隔离级别
- sql事务的隔离级别以及一些MYSQL的命令
- 理解MySql事务隔离机制、锁以及各种锁协议
- 数据库事务的四大特性以及4种事务的隔离级别-以及对应的5种JDBC事务隔离级别
- Mysql的事务以及隔离机制
- 【数据库之事务(一)】事务是什么,以及事务四个特性,以及事务并发问题和隔离级别
- MySQL的InnoDB默认隔离级别的幻读问题
- MySQL表类型MyISAM/InnoDB的区别(解决事务不回滚的问题)(转)
- 理解MySql事务隔离机制、锁以及各种锁协议
- mysql innodb事务的隔离级别和锁的关系
- 数据库并发的五个问题以及四级封锁协议与事务隔离的四个级别
- MySQL(25):事务的隔离级别出现问题之 不可重复读
- Mysql事务隔离导致的问题
- MySQL Innodb事务编程问题和处理
- 事务的隔离级别以及Mysql事务的使用
- 理解MySql事务隔离机制、锁以及各种锁协议
- Mysql InnoDB事务的隔离级别
- MySQL 事务问题及隔离级别