UNDO与REDO表空间区别.docVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
弄懂几个概念: redo是重做日志文件,是oracle数据库的日志文件.oracle的重做日志有两种:在线重做日志以及归档重做日志。 在线重做日志:主要用于由于数据库主机掉电等原因导致实例失败,此时oracle采用在线重做日志在数据库启动时将数据库恢复到归档重做日志:主要用于介质失败,比如:磁盘受损。此时需要使用对磁盘上的数据备份的归动重做日志文件将该磁盘上的数据恢复到该归档文件数据所在的时间点上,然后再使用在线重做日志文件将适合的时间点上。 归档重做日志文件实质是被添满的旧的在线重做日志的副本。归档重做日志文件是数据库的历史数据。 在线重做日志在每个数据库中至少有两个重做日志组,每个日志组中至少有一个重做日志文件,这些在线重做日志组是循环使用的,当日志组1被写到最后时,然后自动切换到日志组2;当日志组2也被写满时,再切换到日志组1。 undo与redo相反,redo是恢复数据,用于在事务失败时重放事务,undo是撤消一条语句或者一组语句的作用。undo是存储在数据库内部的段或者表空间中(undo如果是手动管理,则使用undo段来管理;如果undo使用AUM管理UNDO,则undo使用表空间来自动管理)。 注意:在undo并不是物理的恢复到执行语句之前或者事务之前的样子,只是逻辑的恢复到原来的样子,所有修改只是逻辑的取消,但是数据结构和数据块在回滚之后也大不相同。原因是在多用户系统中,有很多事务是并发进行的,当一个事务修改一个数据并且被回滚,但是该数据在该用户对该数据做过修改之后也也有被其他用户修改,这个时候如果是对该事务修改的数据块回滚到原来数据的物理样子,就有可能将后来的事务所做的修改给覆盖掉。所以回滚不是一个简单的物理的恢复,而是逻辑恢复。 例如:做下面的步骤: SQL drop table t; 表已删除。 SQL create table t 表已创建。 SQL select * from t; 未选定行 SQL set autotrace traceonly statistics SQL select * from t; 未选定行 统计信息 ---------------------------------------------------------- ? ?? ???992??bytes sent via SQL*Net to client ? ?? ???374??bytes received via SQL*Net from client ? ???1??SQL*Net roundtrips to/from client SQL set autotrace off; 注意:在每个用例做2次全表扫描,这样是为了避免解析和优化期间优化器可能产生的额外的I/O,测试只需要比较第二次的查询情况 ? ??? SQL insert into t select * from all_objects; 统计信息 ----------------------------------------------------- ? ?? ???676??bytes sent via SQL*Net to client ? ?? ???575??bytes received via SQL*Net from client ? ?? ?? ? 4??SQL*Net roundtrips to/from client SQL rollback; 回退已完成。 SQL select * from t; 未选定行 SQL set autotrace traceonly statistics SQL select * from t; 未选定行 统计信息 ---------------------------------------------------------- ? ?? ???992??bytes sent via SQL*Net to client ? ?? ???374??bytes received via SQL*Net from client ? ?? ?? ? 1??SQL*Net roundtrips to/from client SQL set autotrace off; 分析:在进行插入操作的时候数据库为该表分配可新的数据块,表示表所占用的空间变大。进行插入操作,表得到新的数据块,然后格式化新的数据块,然后准备放数据进入;此时另一个事务是回滚这些数据,此时回滚并不能将新分配给表的空间给撤消掉,也不能取消对数据块的格式化操作,实际做的是与原来的逻辑相反的工作,insert操作相反的操作是delete,delete相反的操作是insert操作,操作相反的操作是另外执行一个update操作将其变为原来的行。 ? ?? ?

文档评论(0)

kehan123 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档