Oracle Undo与脏读解析

  1. 云栖社区>
  2. 博客>
  3. 正文

Oracle Undo与脏读解析

邴越 2016-05-03 17:41:15 浏览1093
展开阅读全文

Undo就是用来记录保存事务操作过程中的数据,如果事务发生错误,可以之前的数据进行填补。

Undo segment 是保存在表空间上的。Undo 大小是固定的,既然是固定的也就是有限的。如果保存的记录非常多,那么它就会被占满,新记录的数据会覆盖掉最早的数据。

在Oracle数据库中,undo主要有三大作用:提供一致性读(Consistent Read)、回滚事务(Rollback
Transaction)以及实例恢复(Instance Recovery)

一致性读是相对于脏读(DirtyRead)而言的。

A事务读取B事务尚未提交的更改数据,并在这个数据的基础上操作。如果恰巧B事务回滚,那么A事务读到的数据时不被承认的。

假设某个表T中有10000条记录,获取所有记录需要15分钟时间。

当时间为9点整,某用户A发出一条查询语句:select





























网友评论

登录后评论
0/500
评论
邴越
+ 关注