oracle闪回

转载 2012年03月25日 17:17:37

1,闪回数据库到之前某时间点(在安装时需要开放闪回功能)
不支持表空间删除
 select name from v$database;
 --看是否打开闪回功能
 select flashback_on,name from v$database;
 select name from v$bgprocess where paddr<>'00' order by 1;


打开闪回功能
SQL> shutdown immediat
SQL> startup mount
SQL> alter database flashback on;
SQL> alter database open;
修改闪回时间(默认是一天1440)
SQL> alter system set db_flashback_retention_target=2880

RMAN> backup recovery files;--执行此程序,必须要有磁带
执行数据库闪回,必须是在mount,readonly状态
如果重建了控制文件,则修改控制文件以前的数据是不可以闪回的。
例子;
create table t2( a int);
insert into t2 values(1);
insert into t2 values(2);
insert into t2 values(5);
alter system switch logfile;
t2 10:35
insert into t2 values(100);
alter system switch logfile;
insert into t2 values(200);
闪回到某时间点
FLASHBACK DATABASE TO TIME = TO_DATE('2004-05-27 16:00:00','YYYY-MM-DD HH24:MI:SS'); 
FLASHBACK DATABASE   2  TO TIMESTAMP(SYSDATE-1/24); 
查日志进程
select * from v$log;
恢复到某过程sequence为查询的sequence,THREAD
把状态置为mount状态
flashback database to sequence=58 thread=1;
打开数据库
alter database open resetlogs;

 

2,闪回drop表,数据(普通用户都可以操作)
原理:是把放到数据库回收站的对象,数据拉回来
凡不放回收站的对象都不能闪回.
SQL>create table t1(a int);
SQL>drop table t1;
闪回后,把删除的表,及索引都会恢复
SQL>flashback table t1 to before drop; 
语法:FLASHBACK TABLE <table_name> TO BEFORE DROP [RENAME TO <new_name>]

可以用下面的命令或查询查看删除的表;
show recyclebin;
select * from recyclebin --where ORIGINAL_NAME='T1';
DBA的回收站
SELECT owner, original_name, object_name,
        type, ts_name, droptime, related, space 
FROM dba_recyclebin 
WHERE can_undrop = 'YES';
用户回收站
SELECT original_name, object_name,        
       type, ts_name, droptime, related, space 
FROM user_recyclebin 
WHERE can_undrop = 'YES';

表实际不没有删除,只是改了一个名子,放到回收站了
索引名子依然没变。
a,用SYS用户删除的表不可以闪回。

conn / as sysdba
alter table cbsd.t1 move tablespace system;
drop table cbsd.t1;
则不可以闪回
b.索引,物化视图,删除后不可以闪回

3.闪回事务查询
alter table t1 enable row movement;
查询所有可以撤消的操作
SELECT versions_xid as xid,
       versions_startscn,
       versions_endscn,
       versions_operation  
FROM t1 VERSIONS between scn minvalue and maxvalue
WHERE a = 20;

撤消数据
update 3-->5 undo data
数据放在undo tablespace

sql>show parameter undo;
sql>select file_name from dba_data_files where tablespace_name='UNDOTBS1';
闪回数据:RVWR+闪回日志+归档日志
闪回现有表:undo tablespace
闪回删除表:表原来物理位置


转载出处:http://blog.csdn.net/aptweasel/article/details/3867059

相关文章推荐

闪回oracle

  • 2015年02月10日 16:47
  • 413B
  • 下载

Oracle闪回详解--实验

  • 2014年11月02日 18:37
  • 8KB
  • 下载

oracle数据闪回功能(恢复误删除的表信息)

1  ORACLE用PL/SQL提交数据后执行回滚的方法 SELECT * FROM TABLE_1 AS OF TIMESTAMP TO_TIMESTAMP('20080606 20:00:00'...

oracle数据闪回

  • 2013年12月24日 22:26
  • 413KB
  • 下载

Oracle 10g 数据恢复(闪回FLAHBACK)

1、闪回数据库 Flashbackdatabase(根据误操作时间闪回数据) ·DB_RECOVER_FILE_DEST ·DB_RECOVER_FILE_DEST_SIZE 这两个参数来确...

oracle闪回数据库

  • 2011年07月27日 10:10
  • 648KB
  • 下载

Oracle闪回特性

在利用闪回功能前需要确认: 1、用户有对dbms_flashback包有执行权限! 2、进行闪回查询必须设置自动回滚段管理,在init.ora设置参数UNDO_MANAGEMENT=AUTO,参数...

oracle闪回技术

  • 2017年08月23日 08:46
  • 34KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:oracle闪回
举报原因:
原因补充:

(最多只允许输入30个字)