您现在的位置是:首页 >

oracle数据库关闭归档 丢失归档日志文件后数据库应当如何恢复[2]

火烧 2023-02-25 23:10:03 1053
丢失归档日志文件后数据库应当如何恢复[2]   这里是Oracle使用其硬线路的位置 由于转储的数据文件不能恢复到与其他文件一致的位置 所以可能存在中断的数据并且Oracle不允许正常打开数据库   

丢失归档日志文件后数据库应当如何恢复[2]  

  这里是Oracle使用其硬线路的位置 由于转储的数据文件不能恢复到与其他文件一致的位置 所以可能存在中断的数据并且Oracle不允许正常打开数据库

  第 步 设置未文档化的实例参数并打开数据库

  在初始化参数文件中首先需要将job_queue_processes设置为 然后设置_allow_resetlogs_corruption=TRUE 更改该参数后 切换到保存新控制文件的目录 第一步创建的位置 然后以 SYSDBA连接并运行新的控制文件创建脚本

  此时数据库可以打开了

  SQL> SELECT COUNT(*) FROM OE orders;

  第 步 执行导出并提取数据

  在这一步可以很容易的看到那些表导出了全部的数据

  第 步 转储备份的数据库

  这一步 以及下面两步可选 这三步结合在一起允许提取更多的数据 这一步从备份的数据库转储可以高效的撤销任何由于使用_allow_resetlogs_corruption参数造成的毁坏 因此 这一步不会恢复任何丢失的数据文件

  第 步 使毁坏的数据文件offline

  ALTER DATABASE DATAFILE /u /oradata/PRD/ordtab dbf OFFLINE;

  这一步得到数据库的完全一致性状态

  第 步 执行导出并提取额外的数据

  这一步可能能够提取从第四步不能提取的额外数据 如索引中的数据

  第 步 转储数据库

  这是最后一次转储数据库 这一步正式回滚数据库到使用隐含参数前那一刻 然后将数据库返回到正常状态 如果从第五步转储以来没有更新任何数据 可以跳过这一步

  第 步 删除有问题的表空间

  首先需要查看是否有完整性约束限制 使用以下查询

  SELECT CR constraint_name  FROM dba_constraints CR dba_constraints CP dba_tables TP dba_tables TR  WHERE CR r_owner = CP owner  AND CR r_constraint_name = CP constraint_name  AND CR constraint_type = R   AND CP constraint_type IN ( P U )  AND CP table_name = TP table_name  AND CP owner = TP owner  AND CR table_name = TR table_name  AND CR owner = TR owner  AND TR tablespace_name <> ORDTAB   AND TP tablespace_name = ORDTAB ;

oracle数据库关闭归档 丢失归档日志文件后数据库应当如何恢复[2]

  如果有约束 可能需要创建重建脚本 如果使用export dump重建数据 约束可以从导出文件转储

  DROP TABLESPACE ordtab INCLUDING CONTENTS CASCADE CONSTRAINTS;

  第 步 重建表空间

  第 步 重建数据

  执行导入后 结束

lishixinzhi/Article/program/SQL/201311/16188  
永远跟党走
  • 如果你觉得本站很棒,可以通过扫码支付打赏哦!

    • 微信收款码
    • 支付宝收款码