Oracle恢复

一.删除的表恢复

flashback table  tablename to before drop 

二.恢复数据库到某段时间(注意清空的数据不能恢复)查找行移动有没有开启,修改行移动开启

select a.row_movement  from user_tables  where a.table_name=''

alter table tablename enable row movement

flashback table tablename to timestamp to_timestamp(‘20171120 09:30:30’   ‘yyyymmdd hh24:mi:ss’)

 

三.truncate b表的恢复

1.解压下载下来的FY_Recover_Data.pck

2.使用sys用户执行解压后的脚本

SQL> @/home/oracle/FY_Recover_Data.SQL

这个脚本实际是在sys用户下创建了一个名为FY_Recover_Data的package

3.查找表的磁盘位置

SQL> select file_name from dba_data_files f, dba_tables t where t.owner='PBCPCR' and t.table_name='A' and t.tablespace_name = f.tablespace_name;

--/usr/oracle/oradata/pbcpcr/users01.dbf;

4.用sys用户执行下面语句

declare
      tgtowner varchar2(30);
      tgttable varchar2(30);
      datapath varchar2(4000);
      datadir varchar2(30);
      rects varchar2(30);
      recfile varchar2(30);
      rstts varchar2(30);
      rstfile varchar2(30);
      blksz number;
      rectab varchar2(30);
      rsttab varchar2(30);
      copyfile varchar2(30);
begin
      tgtowner := 'PBCPCR'; --table owner
      tgttable := 'A';  --table name
      datapath := '/usr/oracle/oradata/pbcpcr/';    --必须和被truncate表所在的数据文件的目录相同
      datadir := 'FY_DATA_DIR';        --oracle中目录的名字,可以修改
      Fy_Recover_data.prepare_files(tgtowner, tgttable, datapath, datadir, rects, recfile, rstts, rstfile, blksz);
      Fy_Recover_data.fill_blocks(tgtowner, tgttable, datadir, rects, recfile, rstts, 8, tgtowner, tgtowner, rectab, rsttab, copyfile);
      Fy_Recover_data.recover_table(tgtowner, tgttable, tgtowner, rectab, tgtowner, rsttab, datadir, datadir, recfile,datadir, copyfile, blksz);
end;

4.使用sys用户把恢复的数据从pbcpcr.a$$中插回pbcpcr.a表

SQL> insert into pbcpcr.a select * from pbcpcr.a$$;
13 rows created.

 5.使用sys用户删除恢复时产生的2个表空间及数据文件

SQL> drop tablespace fy_rec_data including contents and datafiles;
Tablespace dropped.
SQL> drop tablespace fy_rst_data including contents and datafiles;
Tablespace dropped.

 

posted @ 2017-11-30 18:15  存在的痕迹  阅读(670)  评论(0编辑  收藏  举报