当前位置:  数据库>oracle

undo表空间的作用及ORA-01555

    来源: 互联网  发布时间:2017-05-19

    本文导语: 一、当我们发出DML语句,update t set col = ‘B’ where col = ‘A’;Oracle内部是怎么执行的呢: 1、在shared pool内进行解析,生成执行计划(具体请先了解oracle内存结构中共享池); 2、通过执行计划找到col=’A’数据的位置,例如此数...

一、当我们发出DML语句,update t set col = ‘B’ where col = ‘A’;Oracle内部是怎么执行的呢:

1、在shared pool内进行解析,生成执行计划(具体请先了解oracle内存结构中共享池);

2、通过执行计划找到col=’A’数据的位置,例如此数据存在10号数据文件54号数据块内;

3、进程在buffer cache(详细请先了解oracle内存结构中buffer cache)中找到空闲的undo块,如果没有,则到undo表空间中找到一个可以使用的undo块,并调用到buffer cache中,假设次undo表空间为11号数据文件,此undo块为24号数据块;

4、将改变前的值,也就是A放入到undo块中;

5、由于undo数据块发生变化,所以产生重做记录,假设重做记录行号为120;

行号

事务id

File#

Block#

row

column

value

120

T1

11

24

10

col

A

6、从buffer cache中找到54号数据文件,如果没有发现,从10号数据文件中调用;

7、将B写入到54号数据块中,由于数据块发生了变化,所以产生重做记录,行号为121;

行号

事务id

File#

Block#

row

column

value

121

T1

10

54

10

col

B

8、控制权返回给用户,在SQL*PLUS中会显示光标下移;

9、当用户发出commit命令时,会触发LGWR进程,将120和121两条重做日志从logbuffer中写入到联机日志文件中,同时将54号数据块和24号undo块的头部所记录的事务状态标记设置为已经提交;

10、此时54号数据块和24号数据块并不一定被DBWn写入到10号和11号数据文件中(存在于内存中),此时称之为脏块,只有当脏块达到一定程度才会触发DBWn将脏块写入到数据文件中;


    
 
 

您可能感兴趣的文章:

 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java命名空间javax.swing.undo类stateedit的类成员方法: undo定义及介绍
  • Oracle释放undo表空间
  • java命名空间javax.swing.undo接口undoableedit的类成员方法: undo定义及介绍
  • 如何Shrink Undo表空间,释放过度占用的空间
  • java命名空间javax.swing.undo类undomanager的类成员方法: undo定义及介绍
  • java命名空间javax.swing.undo类abstractundoableedit的类成员方法: undo定义及介绍
  • java命名空间javax.swing.text类defaultstyleddocument.attributeundoableedit的类成员方法: undo定义及介绍
  • java命名空间javax.swing.text类abstractdocument.defaultdocumentevent的类成员方法: undo定义及介绍
  • java命名空间javax.swing.text类abstractdocument.elementedit的类成员方法: undo定义及介绍
  • java命名空间java.awt.event类keyevent的类成员方法: vk_undo定义及介绍
  • java命名空间javax.swing.undo类compoundedit的类成员方法: edits定义及介绍
  • java命名空间javax.swing.undo接口undoableedit的类成员方法: getundopresentationname定义及介绍
  • java命名空间javax.swing.undo类undomanager的类成员方法: edittobeundone定义及介绍
  • java命名空间javax.swing.undo类undomanager的类成员方法: canundoorredo定义及介绍
  • java命名空间javax.swing.undo类undomanager的类成员方法: undoorredo定义及介绍
  • java命名空间javax.swing.undo类stateedit的类成员方法: poststate定义及介绍
  • java命名空间javax.swing.undo类undoableeditsupport的类成员方法: updatelevel定义及介绍
  • java命名空间javax.swing.undo类undoableeditsupport的类成员方法: createcompoundedit定义及介绍
  • java命名空间javax.swing.undo类stateedit的类成员方法: end定义及介绍
  • java命名空间javax.swing.undo类undoableeditsupport的类成员方法: compoundedit定义及介绍
  • java命名空间javax.swing.undo类cannotredoexception的类成员方法: cannotredoexception定义及介绍
  • java命名空间javax.swing.undo类stateedit的类成员方法: object定义及介绍
  • Oracle 管理Undo数据
  • java命名空间javax.swing.undo类stateedit的类成员方法: prestate定义及介绍
  • semop不使用SEM_UNDO的问题
  • java命名空间javax.swing.undo类undoableeditsupport的类成员方法: beginupdate定义及介绍
  • linux command无法撤消mv命令,在linux下没有undo.刚google下,看到老外说的一句比较经典的话。
  • java命名空间javax.swing.undo类stateedit的类成员方法: rcsid定义及介绍
  • [Oracle] 解析在没有备份的情况下undo损坏怎么办
  • java命名空间javax.swing.undo类undoableeditsupport的类成员方法: getupdatelevel定义及介绍
  • Oracle undo_management参数不一致错误


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,