ITPub博客

首页 > Linux操作系统 > Linux操作系统 > 修改一个数据块Oracle需要做的工作

修改一个数据块Oracle需要做的工作

原创 Linux操作系统 作者:wei-xh 时间:2012-06-21 12:29:59 0 删除 编辑
修改一个数据块Oracle需要做的工作(从写的角度做的描述,latch等其他角度没做描述):
1)修改Undo段头块登记一个事务,标记事务开始
2)产生步骤一的Redo Log
3)真正修改数据块前,先把旧镜像记录在UNDO块用来做回滚
4)产生步骤3的Redo Log
5)修改数据块(我们真正想进行的操作)
6)产生步骤5的Redo Log
7)修改Undo 段头块记录事务结束
8)产生步骤7的Redo Log
为了容易理解,Redo的产生都放在了修改操作之前,Oracle真实发生的操作与我描述的相反,都是先产生Redo才会去修改对应的块。
我们只是想修改一个数据块,Oracle做了8个工作来进行。你可能会指出,我这样的描述存在水分,其中步骤1,2,7,8一个事务只
需要做一次,一个事务如果存在多次修改,每个数据块只有3,4,5,6步骤是都需要做的(那也是4倍的工作量),1,2,7,8一个
事务只需要一次。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22034023/viewspace-733547/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
Oracle ACE组成员,DBGeeK用户组发起人。曾在DTCC、ORACLE技术嘉年华、Gdevops等公开场合做过数据库技术专题分享,2017年应Oracle邀请在世界最大的数据库会议OOW上做技术分享。组织翻译了《拨云见日,解密Oracle ASM内核》一书。

注册时间:2009-07-04

  • 博文量
    422
  • 访问量
    2281009