1、开启
当系统 INI 参数 ENABLE_FLASHBACK 置为 1 时,闪回功能开启,可以使用闪回表或进行闪回查询。DM MPP 环境暂不支持闪回功能。
2、作用
闪回表是在数据库联机时,通过只回退对指定表及其相关对象所做的更改,将表里的数据回退到历史的某个时间点,而不需要执行传统的时间点恢复操作。比如回退到用户误删除数据之前的时间点,从而将误删除的数据恢复回来,在这个操作过程中,数据库仍然可用而且不需要额外的空间。
3、原理
闪回表利用的是 UNDO 表空间里所记录的数据被改变前的值。因此,如果因保留时间超过了初始化参数 UNDO_RETENTION 所指定的值,从而导致闪回表时所需要的 UNDO 数据被其他事务覆盖的话,那么就不能将表中数据恢复到指定的时间了。
4、使用示例
使用闪回功能需要先开启闪回参数 ENABLE_FLASHBACK。
由于回滚段默认每秒种都会自动清理,所以需要延长回滚记录的保留时间,单位是秒。回滚段参数太大容易引发回滚段膨胀,这里设置为 1200s。示例语句如下所示:
sql
ALTER SYSTEM SET 'ENABLE_FLASHBACK'=1 BOTH;
ALTER SYSTEM SET 'undo_retention'=1200 BOTH;
5、闪回到指定时间点
1、创建表,初始化数据
sql
DROP TABLE T;
CREATE TABLE T(C1 INT);
INSERT INTO T SELECT LEVEL CONNECT BY LEVEL < 4;
COMMIT;
SELECT * FROM T;
查询结果如下:
2、确定当前的时间
sql
SELECT SYSDATE;
3、修改数据
sql
DELETE FROM T WHERE C1=3;
INSERT INTO T VALUES(4);
COMMIT;
SELECT * FROM T;
4、闪回查询
sql
SELECT * FROM T when TIMESTAMP '2024-12-14 16:19:06'