1、flashback简介:
flashback 按使用的频率,一般分下面四种: 1>flashback query 闪回表的记录,用于数据表记录的恢复; 2>falshabck Table 闪回数据表; 3>flashback drop 回收数据库表,用于表误删除后的恢复; 4>flashback database 闪回数据库,将数据库还原到某个时间点。2、与flashback相关的系统字典表:--查看回收站SELECT * FROM DBA_RECYCLEBIN ORDER BY droptime DESC;SELECT * FROM RECYCLEBIN ORDER BY droptime DESC;--当前用户的回收站--查询SCN与时间的对应关系select scn,to_char(time_dp,'yyyy-mm-dd hh24:mi:ss') from sys.smon_scn_time ORDER BY time_dp DESC;SELECT MAX(SCN) FROM sys.smon_scn_time; --最大/最新的SCN号SELECT CURRENT_SCN FROM V$DATABASE;--查询当前的scn3、闪回表记录:/*****************************FLASHBACK QUERY**************************/--恢复表中被删除的记录DELETE FROM yag_xtyhxx WHERE yhmc LIKE 'RZ%';--操作SELECT COUNT(*) FROM yag_xtyhxx WHERE yhmc LIKE 'RZ%';--表名后指定as of timestamp子句查询SELECT COUNT(*) FROM yag_xtyhxx AS OF TIMESTAMP to_date('2014-06-12 17:24','YYYY-MM-DD hh24:mi:ss') WHERE yhmc LIKE 'RZ%';--表名后指定as of SCN 子句查询SELECT COUNT(*) FROM yag_xtyhxx AS OF SCN 12049699 WHERE yhmc LIKE 'RZ%';--禁用表上的触发器
SELECT * FROM DBA_TRIGGERS WHERE instr(LOWER(trigger_name),'yag_xtyhxx')>0;--ALTER TRIGGER XXXX DISABLE;--恢复表上的触发器--ALTER TRIGGER XXXX ENABLE;--插入数据INSERT INTO YAG_XTYHXX SELECT COUNT(*) FROM YAG_XTYHXX AS OF TIMESTAMP TO_DATE('2014-06-12 17:24', 'YYYY-MM-DD hh24:mi:ss');--to_date()也可以使用 to_timestamp() --FROM yag_xtyhxx AS OF SCN 12049699 WHERE YHMC LIKE 'RZ%';4、闪回数据表:/*****************************FLASHBACK TABLE**************************/DELETE FROM yag_xtyhxx WHERE yhmc LIKE 'RZ%';--操作SELECT COUNT(*) FROM yag_xtyhxx WHERE yhmc LIKE 'RZ%';--激活行移动特征ALTER TABLE yag_xtyhxx ENABLE ROW MOVEMENT;--利用闪回特性,直接恢复到删除时间点前FLASHBACK TABLE yag_xtyhxx TO TIMESTAMP to_date('2014-06-12 16:50','YYYY-MM-DD hh24:mi:ss');--时间点可以设定5、闪回drop:/*****************************FLASHBACK DROP**************************/--恢复被删除的表DROP TABLE yag_xtyhxx;--purge TABLE yag_xtyhxx; --清空回收站里的yag表FLASHBACK TABLE yag_xtyhxx TO BEFORE DROP;6、闪回数据库:/*****************************FLASHBACK DATABASE**************************/使用flashback database 需满足下面条件:1>数据库已设置 flashback闪回恢复区; 检查是否开启闪回恢复区: SQL>show parameter db_recovery_file;2>数据库已开启归档; 检查是否开启归档: archive log list;3>flashback database 已开启; flashback database 默认是关闭的,查看flashback database开启状态:select flashback_on from v$database;--使用SCN恢复flashback database to SCN SCN号;--使用timestamp恢复flashback database to timestamp to_date('2014-06-12 16:50','YYYY-MM-DD hh24:mi:ss'); --to_date()也可以使用 to_timestamp()