在数据库系统中,脏读(Dirty Read)、幻读(Phantom Read)和不可重复读(Non-repeatable Read)是几种常见的并发控制问题。它们在多个并发事务同时对数据库进行读写时可能发生,导致数据的一致性受到破坏。解决这些问题需要合适的并发控制机制。 1. 脏读(Dirty Read) 脏读指的是一个事务读取了另一个事务尚未提交的数据。
所以在设置数据库的事务隔离级别时需要做一下权衡,MySQL默认是可重复读的级别。 读未提交 读未提交(Read Uncommitted),是最低的隔离级别,所有的事务都可以看到其他未提交的事务的执行结果。只能防止第一类更新丢失,不能解决脏读,可重复读,幻读,所以很少应用于实际项目。 读已提交 读已提交(Read Committed), 在该...
1.脏读 2.不可重复读 3.幻读 三、MVCC机制 MySQL三种行锁 一、数据库事务的ACID是什么? 提到数据库事务,我们都知道有的四大特性 ACID,那么都分别是什么意思呢? 原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,完全应用到数据库,要么全部失败回滚,不会对数据库产生任何影响。 一致性(Consistency)...
1.脏读: 脏读是指一个事务在处理数据的过程中,读取到另一个未提交事务的数据。 2.不可重复读: 不可重复读是指对于数据库中的某个数据,一个事务范围内的多次查询却返回了不同的结果,这是由于在查询过程中,数据被另外一个事务修改并提交了。 不可重复读和脏读的区别是,脏读读取到的是一个未提交的数据,而...
这就是并发事务所产生的一些问题。具体来说就是:脏读、不可重复读和幻读。 一、概念说明 以下几个概念是事务隔离级别要实际解决的问题,所以需要搞清楚都是什么意思。 1、脏读 脏读指的是读到了其他事务未提交的数据,未提交意味着这些数据可能会回滚,也就是可能最终不会存到数据库中,也就是不存在的数据。读...
脏读(Dirty Read)是指在数据库事务中,一个事务读取了另一个未提交事务中的数据。当一个事务修改数据但还没有提交时,另一个事务读取了这个未提交的数据。如果未提交的事务最终被回滚,那么另一个事务读取到的数据实际上是无效的或错误的。脏读可能导致不一致的数据状态和不正确的结果。
可以看到,会话 2 的更新操作还没结束,会话 1 就读到了同一条记录,结果却没有产生脏读。如何实现的呢? 首先,我说说自己以前的理解:逻辑上有点像 java 中的CopyOnWriteArrayList,当事务隔离级别为已提交时,不会在实际记录上进行写操作,而是将需要修改的记录缓存一份进行更改,事务提交时才把这部分缓存刷入实际记录,...
脏读:所谓的脏读,其实就是读到了别的事务回滚前的脏数据。比如事务B执行过程中修改了数据X,在未提交前,事务A读取了X,而事务B却回滚了,这样事务A就形成了脏读。 概述 分享之前关于数据库脏读、不可重复读、幻读的相关笔记,也做个备忘! 如果没有事务隔离,会出现什么样的情况?
1 脏读、不可重复读、幻象读概念 1.1 脏读 脏读:指当一个事务正在访问数据,并且对数据进行了修改,而这种数据还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。因为这个数据还没有提交那么另外一个事务读取到的这个数据我们称之为脏数据。依据脏数据所做的操作肯能是不正确的。