简述Oracle中完全恢复与不完全恢复是什么?

Oracle中的完全恢复和不完全恢复主要指的是数据库恢复过程中所使用的策略和方法。

完全恢复:利用重做日志或增量备份将数据块恢复到最接近当前时间的时间点。之所以叫做完整恢复是由于Oracle应用了归档日志和联机重做日志中所有的修改。当数据文件出现介质失败时,使用os命令复制数据文件备份,并使用SQL恢复命令应用归档日志和重做日志,最终将数据文件恢复到失败之前的最近时间点。

不完全恢复:利用备份产生一个非当前版本的数据库。换句话说,恢复过程中不会应用备份产生后生成的所有的重做日志。通常在下列情况下生成整个数据库的不完整恢复:

  1. 介质失败损坏了几个或全部的联机重做日志文件。
  2. 用户操作造成的数据丢失,比如,用户误删除了一张表。
  3. 由于个别归档日志文件的丢失无法进行完整的恢复。
  4. 丢失了当前的控制文件,必须使用备份的控制文件打开数据库。

为了执行不完整介质恢复,必须使用恢复时间点以前的备份来还原数据文件,并在恢复完成后使用RESETLOG选项打开数据库。resetlogs参数在不完全恢复期间,通常需要使用resetlogs命令打开数据库,这是因为我们要从已经建立的现有重做日志流中脱离出来。

发表评论

后才能评论