MySQL数据库中的四种隔离级别

原文:MySQL数据库中的四种隔离级别

事务的隔离性比想象的要复杂,在 SQL 标准中定义了四种级别的隔离级别。通常而言,较低级别的隔离通常可以执行更高的并发,系统的开销也更低

READ UNCOMMITTED

该级别为未提交读。在该级别中,事务中的修改即使没有提交,对其他事务也都是可见的。事务可以读取未提交的数据,这也被称为脏读。这个级别会导致很多的问题,从性能上来说,它不会比其他级别好太多,但缺乏其他级别的很多好处。除非真的有非常必要的理由,在实际应用中一般很少使用。

READ COMMITTED

该级别为提交读。大部分数据库系统的默认隔离级别都是它,但 MySQL 不是。该级别满足隔离性的简单定义:一个事务开始时,只能“看见”已经提交的事务所做的修改。换而言之,一个事务从开始直到提交之前,所做的任何修改对其他事务都是不可见的。这个级别有时候也叫做不可重复读,因为两次执行同样的查询,可能会得到不一样的结果。

REPEATABLE READ

该级别为可重复读,它是 MySQL 默认的事务隔离级别。它解决了脏读的问题,保证了在同一个事务中多次读取同样记录的结果是一致的。

但是理论上,该级别却无法解决另外一个问题:幻读。所谓幻读,指的是当某个事务在读取某个范围内的记录时,另外一个事务又在该范围内插入了新的记录,当之前的事务再次读取该范围的记录时,会产生幻行

幻读示例: 第一个事务对一个表中的数据进行了修改,比如这种修改涉及到表中的“全部数据行”。同时,第二个 事务也修改这个表中的数据,这种修改是向表中插入“一行新数据”。那么,以后就会发生操作第一个 事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样.

InnoDB存储引擎通过多版本并发控制解决了幻读的问题。

SERIALIZABLE

该级别为可串行化,是最高的隔离级别。它通过强制事务串行执行,避免了前面说的幻读问题。简而言之,该级别会在读取的每一行数据上都加锁,所以可能导致大量的超时和锁争用问题。

实际应用中也很少使用这个隔离级别,只有在非常需要确保数据的一致性而且可以接受没有并发的情况下,才考虑采用该级别。

隔离级别 脏读可能性 不可重复读可能性 幻读可能性 加锁读
READ UNCOMMITTED Yes Yes Yes No
READ COMMITTED No Yes Yes No
REPEATABLE READ No No Yes No
SERIALIZABLE No No No Yes

原文地址:https://www.cnblogs.com/lonelyxmas/p/10336400.html

时间: 2024-10-23 05:52:03

MySQL数据库中的四种隔离级别的相关文章

关于数据库中的四种隔离级别

1.read uncommitted 可以看到未提交的数据(脏读),举个例子:别人说的话你都相信了,但是可能他只是说说,并不实际做. 2.read committed 读取提交的数据.但是,可能多次读取的数据结果不一致(不可重复读,幻读).用读写的观点就是:读取的行数据,可以写. 3.repeatable read(MySQL默认隔离级别) 可以重复读取,但有幻读.读写观点:读取的数据行不可写,但是可以往表中新增数据.在MySQL中,其他事务新增的数据,看不到,不会产生幻读.采用多版本并发控制(

MySQL系列之二四种隔离级别及加锁

事务 1.定义:所有操作必须成功完成,否则在每个操作中所作的所有更改都会备撤销. 2.事务的ACID 原子性atomicity   一致性consistency   隔离性isolation   持续性durability 2-1.原子性: 事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做 2-2.一致性: 事务执行的结果必须是数据库从一个一致性状态变到另一个一致性状态.因此当数据库只包含成功事务提交的结果时, 就说明数据库处于一致性状态. 2-3.隔离性: 一个事务的执行不能

SQL 标准中的四种隔离级别

READ UNCOMMITED(未提交读) 在RERAD UNCOMMITED级别,事务中的修改,即使没有提交,对其他事务也都是可见的.事务可以读取未提交的数据,这也成为脏读(Dirty Read).这个级别会导致很多问题,从性能上说READ UNCOMMITED 不会比其他的级别好太多,但缺乏其他级别的好多好处,除非有非常必要的理由,在实际的应用中一般很少使用READ UNCOMMITED. READ COMMITED (提交读) 大多数数据库系统的默认隔离级别都是READ COMMITED

数据库事务的四种隔离级别

数据库事务的隔离级别有4个,由低到高依次为: Read uncommitted 未授权读取 读未提交 读可允许其他两个事务不能同时进行写操作 事务B读取事务A为提交的数据 避免更新丢失 会出现脏读 Read committed 授权读取 读提交 读可允许其他 未提交的事务禁止其他事务访问进行 事务A读取数据 事务B更改数据 事务A读取B更改后的数据,前后结果不一致 避免脏读 会出现不可重复读(重复读取结果不同) Repeatable read 可重复读取 读不允许写事务进行 写禁止其他事务进行

数据库事务的四种隔离机制和七种传播行为

MySQL数据库为我们提供的四种隔离级别:(依次解决脏读.不可重复读.幻读) ① Serializable (串行化):可避免脏读.不可重复读.幻读的发生. ② Repeatable read (可重复读):可避免脏读.不可重复读的发生.(Mysql默认的方式) ③ Read committed (读已提交):可避免脏读的发生.(Oracle默认的方式) ④ Read uncommitted (读未提交):最低级别,任何情况都无法保证.(INNODB内部机制) 数据库事务正常执行的四个特性: A

MySql四种隔离级别

什么是事务 事务是应用程序中一系列严密的操作,所有操作必须成功完成,否则在每个操作中所作的所有更改都会被撤消.也就是事务具有原子性,一个事务中的一系列的操作要么全部成功,要么一个都不做. 事务的结束有两种,当事务中的所以步骤全部成功执行时,事务提交.如果其中一个步骤失败,将发生回滚操作,撤消撤消之前到事务开始时的所以操作. 事务的 ACID 事务具有四个特征:原子性( Atomicity ).一致性( Consistency ).隔离性( Isolation )和持续性( Durability

mysql 四种隔离级别

事务的 四个特征(ACID) 事务具有四个特征:原子性( Atomicity ).一致性( Consistency ).隔离性( Isolation )和持续性( Durability ).这四个特性简称为 ACID 特性. 1 .原子性.事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做 2 .一致性.事 务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态.因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态.如果数据库系统 运行中发生故障,有些事务尚未

mysql 事务的四种隔离级别

MYSQL标准定义了4种隔离级别,用来限定事务内外的哪些改变是可见的,哪些是不可见的. 低的隔离级一般支持更高的并发处理,并拥有更低的系统开销. 隔离级别由低到高:Read Uncommitted < Read Committed < Repeatable Read < Serializable. 第一:READ UNCOMMITTED (读取未提交内容) 在该隔离级别,所有事务都可以看到其他未提交(commit)事务的执行结果. 本隔离级别很少用于实际应用,因为它的性能也不比其他级别好

SQL事务的四种隔离级别和MySQL多版本并发控制

SQL标准定义了4类隔离级别,包括了一些具体规则,用来限定事务内外的那些改变时可见的,那些是不可见的.低级别的隔离级一般支持更高的并发处理,并拥有更低的系统开销. ReadUncommitted(读取未提交内容) 在该隔离级别,所有事务都可以看到其他未提交事务的执行结构.本隔离级别很少用于实际应用,因为它的性能也不比其他级别好多少.读取未提交的数据,也被称之为脏读(Dirty Read) ReadCommitted(读取提交内容) 这是大多数数据库系统的默认隔离级别(但不是MySQL默认的).它