事务并发事务隔离级别

RainDream RainDream     2022-08-01     125

关键词:

  

不可重复读(Nonrepeatable Read) 
一个事务的两次读取中,读取相同的资源得到不同的值。当事务T2在事务T1的两次读取之间更新数据,则会发生此种错误(重点在修改) 


幻读(Phantom): 
此概念相对难理解一些。 
事务T1对一定范围内执行操作,T2对相同的范围内执行不兼容的操作,这时会发生幻读。 
如:T1删除符合条件C1的所有数据,T2又插入了一些符合条件C1的数据,则在T1中再次查找符合条件C1的数据还是可以查到,这对T1来说好像是幻觉一样,这时的读取操作称为幻读。(重点在新增或删除

 

以下转自: 事务并发、事务隔离级别

 

并发问题可归纳为以下几类:

 

A.丢失更新:撤销一个事务时,把其他事务已提交的更新数据覆盖(A和B事务并发执行,A事务执行更新后,提交;B事务在A事务更新后,B事务结束前也做了对该行数据的更新操作,然后回滚,则两次更新操作都丢失了)。

B.脏读:一个事务读到另一个事务未提交的更新数据(A和B事务并发执行,B事务执行更新后,A事务查询B事务没有提交的数据,B事务回滚,则A事务得到的数据不是数据库中的真实数据。也就是脏数据,即和数据库中不一致的数据)。

C.不可重复读:一个事务读到另一个事务已提交的更新数据(A和B事务并发执行,A事务查询数据,然后B事务更新该数据,A再次查询该数据时,发现该数据变化了)。

D. 覆盖更新:这是不可重复读中的特例,一个事务覆盖另一个事务已提交的更新数据(即A事务更新数据,然后B事务更新该数据,A事务查询发现自己更新的数据变了)。

 

E.虚读(幻读):一个事务读到另一个事务已提交的新插入的数据(A和B事务并发执行,A事务查询数据,B事务插入或者删除数据,A事务再次查询发现结果集中有以前没有的数据或者以前有的数据消失了)。

数据库系统提供了四种事务隔离级别供用户选择:

A.Serializable(串行化):一个事务在执行过程中完全看不到其他事务对数据库所做的更新(事务执行的时候不允许别的事务并发执行。事务串行化执行,事务只能一个接着一个地执行,而不能并发执行。)。

B.Repeatable Read(可重复读):一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,但是不能看到其他其他事务对已有记录的更新。

C.Read Commited(读已提交数据):一个事务在执行过程中可以看到其他事务已经提交的新插入的记录,而且能看到其他事务已经提交的对已有记录的更新。

D.Read Uncommitted(读未提交数据):一个事务在执行过程中可以看到其他事务没有提交的新插入的记录,而且能看到其他事务没有提交的对已有记录的更新。

 

 

 

丢失更新

脏读

非重复读

覆盖更新

幻像读

未提交读

Y

Y

Y

Y

Y

已提交读

N

N

Y

Y

Y

可重复读

N

N

N

N

Y

串行化

N

N

N

N

N



 

隔离级别

 

数据库系统有四个隔离级别(大多数数据库默认级别为read commited)。对数据库使用何种隔离级别要审慎分析,因为

1. 维护一个最高的隔离级别虽然会防止数据的出错,但是却导致了并行度的损失,以及导致死锁出现的可能性增加。

2. 然而,降低隔离级别,却会引起一些难以发现的bug。

 

SERIALIZABLE(序列化)

 

添加范围锁(比如表锁,页锁等,关于range lock,我也没有很深入的研究),直到transaction A结束。以此阻止其它transaction B对此范围内的insert,update等操作。

 

幻读,脏读,不可重复读等问题都不会发生。

 

REPEATABLE READ(可重复读)

 

对于读出的记录,添加共享锁直到transaction A结束。其它transaction B对这个记录的试图修改会一直等待直到transaction A结束。

 

可能发生的问题:当执行一个范围查询时,可能会发生幻读。

 

READ COMMITTED(提交读)

 

在transaction A中读取数据时对记录添加共享锁,但读取结束立即释放。其它transaction B对这个记录的试图修改会一直等待直到A中的读取过程结束,而不需要整个transaction A的结束。所以,在transaction A的不同阶段对同一记录的读取结果可能是不同的。

 

可能发生的问题:不可重复读。

 

READ UNCOMMITTED(未提交读)

 

不添加共享锁。所以其它transaction B可以在transaction A对记录的读取过程中修改同一记录,可能会导致A读取的数据是一个被破坏的或者说不完整不正确的数据。

 

另外,在transaction A中可以读取到transaction B(未提交)中修改的数据。比如transaction B对R记录修改了,但未提交。此时,在transaction A中读取R记录,读出的是被B修改过的数据。

 

可能发生的问题:脏读。

 

 

问题

 

我们看到,当执行不同的隔离级别时,可能会发生各种各样不同的问题。下面对它们进行总结并举例说明。

 

幻读

 

幻读发生在当两个完全相同的查询执行时,第二次查询所返回的结果集跟第一个查询不相同。

 

发生的情况:没有范围锁。

 

例子:

 

事务1 事务2
SELECT
 * FROM
users
WHERE
age BETWEEN
10
AND
30
 
 
INSERT
INTO
users VALUES
(
3
, ‘Bob‘
, 27
);
COMMIT;
SELECT
* FROM
users WHERE
age BETWEEN
10
AND
30;

 

 

如何避免:实行序列化隔离模式,在任何一个低级别的隔离中都可能会发生。

 

不可重复读

在基于锁的并行控制方法中,如果在执行select时不添加读锁,就会发生不可重复读问题。

在多版本并行控制机制中,当一个遇到提交冲突的事务需要回退但却被释放时,会发生不可重复读问题。

 

事务1 事务2
SELECT
* FROM
users WHERE
id = 1;
 
 
UPDATE
users SET
age = 21
WHERE
id = 1
;
COMMIT; /* in multiversion concurrency*/
   control, or lock-based READ COMMITTED *
SELECT
* FROM
users WHERE
id = 1;
 
 
COMMIT; /* lock-based REPEATABLE READ */

 

在上面这个例子中,事务2提交成功,它所做的修改已经可见。然而,事务1已经读取了一个其它的值。在序列化和可重复读的隔离级别中,数据库管理系统会返回旧值,即在被事务2修改之前的值。在提交读和未提交读隔离级别下,可能会返回被更新的值,这就是“不可重复读”。

 

有两个策略可以防止这个问题的发生:

1. 推迟事务2的执行,直至事务1提交或者回退。这种策略在使用锁时应用。(悲观锁机制,比如用select for update为数据行加上一个排他锁)

2. 而在多版本并行控制中,事务2可以被先提交。而事务1,继续执行在旧版本的数据上。当事务1终于尝试提交时,数据库会检验它的结果是否和事务1、事务2顺序执行时一样。如果是,则事务1提交成功。如果不是,事务1会被回退。(乐观锁机制)

 

脏读

脏读发生在一个事务A读取了被另一个事务B修改,但是还未提交的数据。假如B回退,则事务A读取的是无效的数据。这跟不可重复读类似,但是第二个事务不需要执行提交。 

 

事务1 事务2
SELECT
* FROM
users WHERE
id = 1;
 
 
UPDATE
users SET
age = 21
WHERE
id = 1
SELECT
FROM
users WHERE
id = 1;
 
 
COMMIT; /* lock-based DIRTY READ */

 

嵌套事务(而不是并发事务)的默认隔离级别是多少?

】嵌套事务(而不是并发事务)的默认隔离级别是多少?【英文标题】:Whatisthedefaultisolationlevelacrossnestedtransactions(insteadofconcurrentones)?【发布时间】:2019-04-2414:14:01【问题描述】:Spring有3种典型的嵌套事务传播:REQUIRED、NEW和NEST... 查看详情

第31讲:mysql事务的并发问题以及事务的隔离级别

文章目录1.事务的并发问题1.1.事务并发之脏读1.2.事务并发之不可重复读1.3.事务并发之幻读2.事务的隔离级别3.模拟事务并发问题的产生以及如何避免3.1.事务并发问题脏读的模拟以及避免3.1.1.模拟事务并发脏读的问题3.1.2.解决事... 查看详情

事务并发之隔离级别

事务事务是作为单个逻辑工作单元执行的一系列操作。一个逻辑工作单元必须有四个属性,称为原子性、一致性、隔离性和持久性(ACID)属性,只有这样才能成为一个事务。事务并发数据库是多个用户(事务)共享的,当多个用户同... 查看详情

事务的隔离级别和传播行为

一、什么是事务隔离  一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。 五个事务隔级别:lsolation的属性值1,default默认的事... 查看详情

事务并发事务隔离级别

  不可重复读(NonrepeatableRead) 一个事务的两次读取中,读取相同的资源得到不同的值。当事务T2在事务T1的两次读取之间更新数据,则会发生此种错误(重点在修改) 幻读(Phantom): 此概念相对难理解一些... 查看详情

事务并发传播性隔离级别(代码片段)

事务并发、传播性、隔离级别(重难点)导读:本节重点在于多线程并发环境下的事务处理、和数据库在并发环境下的表锁和行锁。案例:在新增图书的时候,肯定需要先新增作者。SpringMVC声明式事务事务分... 查看详情

图解数据库事务的隔离级别(代码片段)

...?我在网上所能找到的答案,帮助个人的理解。答案一:事务隔离级别是并发控制的整体解决方案,其实际上是综合利用各种类型的锁和行版本控制,来解决并发问题。锁是数据库并发控制的内部机制,是基础。对用户来说,只... 查看详情

事务隔离级别

事务隔离级别       数据库并发操作存在的异常情况:1.更新丢失(Lostupdate): 两个事务都同时更新一行数据但是第二个事务却中途失败退出导致对数据两个修改都失效了这是系统没有执行任何锁操... 查看详情

事务的隔离级别是啥?

数据库事务的隔离级别有4种,由低到高分别为Readuncommitted、Readcommitted、Repeatableread、Serializable。而且,在事务的并发操作中可能会出现脏读,不可重复读,幻读。1、Readuncommitted读未提交,顾名思义,就是一个事务可以读取另一... 查看详情

事务的特性和隔离级别

1.事务的特性ACID1)原子性(Atomicity)原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。 2)一致性(Consistency)一个事务中,事务前后数据的完整性必须保持一致。 3)隔离性(Isolati... 查看详情

事务隔离级别(代码片段)

事务隔离级别:了解数据库事务的最重要因素事务是数据库管理系统(DBMS)中一个重要的概念,它能够确保数据库操作的完整性和一致性。然而,如果多个事务同时运行并试图访问同一个数据,即想同时保证并发性和一致性,... 查看详情

由事务隔离级别分隔的并发进程死锁

】由事务隔离级别分隔的并发进程死锁【英文标题】:deadlockonconcurrentprocessesseparatedbytransactionisolationlevel【发布时间】:2011-08-2313:36:05【问题描述】:我们有一个工单表。服务器代理作业从游标中的该表中获取100个条目并执行一... 查看详情

事务并发问题及解决

数据库事务的隔离级别数据库事务的隔离级别有4个,由低到高依次为Readuncommitted?、Readcommitted?、Repeatableread?、Serializable?,这四个级别可以逐个解决脏读?、不可重复读?、幻读这几类问题。ReadUnCommitted(读未提交)最低的隔离级别。... 查看详情

并发事务的问题和隔离级别

目录事务的ACID特性并发事务的问题隔离级别悲观锁和乐观锁参考事务的ACID特性原子性(Atomicity):事务是最小的执行单位,不允许分割。事务的原子性确保动作要么全部完成,要么完全不起作用。一致性(Consistency):执行事... 查看详情

事务的特性和隔离级别

事务的特性:ACID原子性:事务是一个不可分割的工作单元,事务中的操作要么都发生,要么都不发生。一致性:一个事务中,事务前后的数据完整性要保持一致。隔离性:多个事务,多个用户并发访问数据库时,一个用户的事... 查看详情

mysql事务和隔离级别

MySQL事务和隔离级别连接管理器: 接受请求 创建线程 认证用户 建立安全连接 并发控制: 最简单机制是使用锁 多版本并发控制:MVCC(使用其他机制)锁: 读锁:共享锁 写锁:独占锁 加锁: LOCKTABLEStb_name{READ|WRITE}; 解锁: UNL... 查看详情

事务的隔离级别

...库操作中,为了有效保证并发读取数据的正确性,提出的事务隔离级别。用途事务的隔离级别是为了保证并发读取数据的正确性。我们的应用在并发处理请求时,对数据库的访问也是并发的,这样就会产生多个事务同时对数据库... 查看详情

锁模块

...问题1、MyISAM和InnoDB关于锁方面的区别是什么?2、数据库事务的四大特性?3、事务隔离级别以及各级别下的并发访问问题?4、InnoDB可重复读隔离级别下如何避免幻读?5、RC、RR级别下的InnoDB的非阻塞读如何实现? 1、MyISAM和In... 查看详情