博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
脏读 幻读 不可重复读
阅读量:7260 次
发布时间:2019-06-29

本文共 1236 字,大约阅读时间需要 4 分钟。

转自:http://www.blogjava.net/hitlang/archive/2009/04/13/265256.html

 

1, 脏读

一个事务读到另一个事务,尚未提交的修改,就是脏读。这里所谓的修改,除了Update操作,不要忘了,还包括

Insert和Delete操作。

脏读的后果:如果后一个事务回滚,那么它所做的修改,统统都会被撤销。前一个事务读到的数据,就是垃圾数据。

举个例子:预订房间。
有一张Reservation表,往表中插入一条记录,来订购一个房间。

 事务1:在Reservation表中插入一条记录,用于预订99号房间。

 事务2:查询,尚未预定的房间列表,因为99号房间,已经被事务1预订。所以不在列表中。

 事务1:信用卡付款。由于付款失败,导致整个事务回滚。

        所以插入到Reservation 表中的记录并不置为持久(即它将被删除)。

现在99号房间则为可用。

所以,事务2所用的是一个无效的房间列表,因为99号房间,已经可用。如果它是最后一个没有被预定的房间,那么这将是一个严重的失误。

注:脏读的后果很严重。

 

2,不可重复读。

在同一个事务中,再次读取数据时【就是你的select操作】,所读取的数据,和第1次读取的数据,不一样了。就是不可重复读。

举个例子:

 事务1:查询有双人床房间。99号房间,有双人床。

 事务2:将99号房间,改成单人床房间。

 事务1:再次执行查询,请求所有双人床房间列表,99号房间不再列表中了。也就是说,

               事务1,可以看到其他事务所做的修改。

在不可重复读,里面,可以看到其他事务所做的修改,而导致2次的查询结果不再一样了。
这里的修改,是提交过的。也可以是没有提交的,这种情况同时也是脏读。

如果,数据库系统的隔离级别。允许,不可重复读。那么你启动一个事务,并做一个select查询操作。

查询到的数据,就有可能,和你第2次,3次...n次,查询到的数据不一样。一般情况下,你只会做一次,select
查询,并以这一次的查询数据,作为后续计算的基础。因为允许出现,不可重复读。那么任何
时候,查询到的数据,都有可能被其他事务更新,查询的结果将是不确定的。

注:如果允许,不可重复读,你的查询结果,将是不确定的。一个不确定的结果,你能容忍吗?

3,幻读

 

事务1读取指定的where子句所返回的一些行。然后,事务2插入一个新行,这个新行也满足事务1使用的查询

where子句。然后事务1再次使用相同的查询读取行,但是现在它看到了事务2刚插入的行。这个行被称为幻象,
因为对事务1来说,这一行的出现是不可思议的。

举个例子:

事务1:请求没有预定的,双人床房间列表。
事务2:向Reservation表中插入一个新纪录,以预订99号房间,并提交。
事务1:再次请求有双人床的未预定的房间列表,99号房间,不再位于列表中。

注:幻读,针对的是,Insert操作。如果事务2,插入的记录,没有提交。那么同时也是脏读。

转载地址:http://crodm.baihongyu.com/

你可能感兴趣的文章
解决cookies存储中文报错问题
查看>>
linux的mtd架构分析【转】
查看>>
js排序算法总结——冒泡,快速,选择,插入,希尔,归并
查看>>
Dubbo xml配置 和注解配置 写法
查看>>
Required MultipartFile parameter 'file' is not present error
查看>>
Golang 笔记 2 函数、结构体、接口、指针
查看>>
在ASP.NET MVC部署AngularJs
查看>>
smokeping网络监控
查看>>
php实现模拟登陆
查看>>
vue ajax获取数据的时候,如何保证传递参数的安全或者说如何保护api的安全
查看>>
Ubuntu 14.04 安装 sysrepo v0.7.5
查看>>
程序员如何成为一个风一样的男子!?
查看>>
Our take on Derby vs. Meteor
查看>>
ASP.NET经典60道面试题
查看>>
我的vim配置
查看>>
【图像处理】最临近插值和双线性内插值算法实现比较
查看>>
【简单项目框架一】Fragment实现的底部导航
查看>>
java 实现WebService 以及不同的调用方式
查看>>
MVC应用程序与多选列表(checkbox list)
查看>>
安卓开发学习1
查看>>