当前位置:网站首页>脏读、幻读和不可重复读
脏读、幻读和不可重复读
2022-07-01 06:29:00 【song854601134】
一、脏读、幻读和不可重复读
一、脏读、不可重复读、幻读
1、脏读:脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据。
例如:
张三的工资为5000,事务A中把他的工资改为8000,但事务A尚未提交。
与此同时,
事务B正在读取张三的工资,读取到张三的工资为8000。
随后,
事务A发生异常,而回滚了事务。张三的工资又回滚为5000。
最后,
事务B读取到的张三工资为8000的数据即为脏数据,事务B做了一次脏读。
2、不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的的数据可能是不一样的。这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读。
例如:
在事务A中,读取到张三的工资为5000,操作没有完成,事务还没提交。
与此同时,
事务B把张三的工资改为8000,并提交了事务。
随后,
在事务A中,再次读取张三的工资,此时工资变为8000。在一个事务中前后两次读取的结果并不致,导致了不可重复读。
3、幻读:是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行。同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据。那么,以后就会发生操作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样。
例如:
目前工资为5000的员工有10人,事务A读取所有工资为5000的人数为10人。
此时,
事务B插入一条工资也为5000的记录。
这是,事务A再次读取工资为5000的员工,记录为11人。此时产生了幻读。
4、提醒
不可重复读的重点是修改:
同样的条件,你读取过的数据,再次读取出来发现值不一样了
幻读的重点在于新增或者删除:
同样的条件,第 1 次和第 2 次读出来的记录数不一样
5、第一类丢失更新
A事务撤销时,把已经提交的B事务的更新数据覆盖了。例如:
这时候取款事务A撤销事务,余额恢复为1000,这就丢失了更新。
6、第二类丢失更新
A事务覆盖B事务已经提交的数据,造成B事务所做的操作丢失
二、如何解决
为了解决上述问题,数据库通过锁机制解决并发访问的问题。根据锁定对象不同:分为行级锁和表级锁;根据并发事务锁定的关系上看:分为共享锁定和独占锁定,共享锁定会防止独占锁定但允许其他的共享锁定。而独占锁定既防止共享锁定也防止其他独占锁定。为了更改数据,数据库必须在进行更改的行上施加行独占锁定,insert、update、delete和selsct for update语句都会隐式采用必要的行锁定。
但是直接使用锁机制管理是很复杂的,基于锁机制,数据库给用户提供了不同的事务隔离级别,只要设置了事务隔离级别,数据库就会分析事务中的sql语句然后自动选择合适的锁。
不同的隔离级别对并发问题的解决情况如图:
注意:事务的隔离级别和数据库并发性是成反比的,隔离级别越高,并发性越低。
如何理解读已提交??
同样开启事务A和事务B两个事务,在事务A中使用 update 语句将 id = 1 的记录行 age 字段改为30。此时,在事务B中使用 select 语句进行查询,我们发现在事务A提交之前,事务B中查询到的记录 age 一直是14,直到事务A提交,此时在事务B中查询,发现 age 的值已经是 30 了。这就出现了一个问题,在同一事务中(本例中的事务B),事务的不同时刻同样的查询条件,查询出来的记录内容是不一样的,事务A的提交影响了事务B的查询结果,这就是不可重复读,也就是读取已提交隔离级别。
所谓的读已提交,是只允许读取提交(commit)后的数据,在commit之前读取的是上次commit后的数据。
边栏推荐
- [ManageEngine Zhuohao] the role of LAN monitoring
- SQL语句
- 华福证券开户是安全可靠的么?怎么开华福证券账户
- SQL语言的学习记录一
- 数据库对象:视图学习记录
- libpng12.so. 0: cannot open shared object file: no such file or directory
- Idea easy to use plug-in summary!!!
- HW(OD)岗面试题
- [ManageEngine Zhuohao] helps Julia college, the world's top Conservatory of music, improve terminal security
- Requests module (requests)
猜你喜欢

Redis安装到Windows系统上的详细步骤

软件工程复习

Record MySQL troubleshooting caused by disk sector damage

C language course set up salary management system (big homework)

谷粒商城-环境(p1-p27)

SystemVerilog learning-08-random constraints and thread control

C语言课设职工信息管理系统(大作业)

C语言课设学生考勤系统(大作业)

Promise
![[self use of advanced mathematics in postgraduate entrance examination] advanced mathematics Chapter 1 thinking map in basic stage](/img/54/f187e22ad69f3985d30376bad1fa03.png)
[self use of advanced mathematics in postgraduate entrance examination] advanced mathematics Chapter 1 thinking map in basic stage
随机推荐
JMM details
If I am in Guangzhou, where can I open an account? Is it safe to open an account online?
JSON module
[ManageEngine Zhuohao] use unified terminal management to help "Eurex group" digital transformation
Interview questions for HW (OD) post
Several ways of gson's @jsonadapter annotation
SystemVerilog learning-09-interprocess synchronization, communication and virtual methods
给逆序对数求原数组
Detailed steps for installing redis on Windows system
Free trial of self-developed software noisecreater1.1
[unity shader ablation effect _ case sharing]
[unity shader amplify shader editor (ASE) Chapter 9]
Chapitre V gestion des entrées / sorties
C language course set up library information management system (big homework)
解决The code generator has deoptimised the styling of xxxx.js as it exceeds the max of 500kb
ManageEngine Zhuohao helps you comply with ISO 20000 standard (IV)
[unity shader stroke effect _ case sharing first]
【#Unity Shader#Amplify Shader Editor(ASE)_第九篇】
What are the functions of LAN monitoring software
数据库对象:视图学习记录