达梦数据库闪回操作

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'
相关推荐
写bug写bug5 分钟前
Java并发编程:优雅的关闭钩子(Shutdown Hook)
java·后端
noravinsc35 分钟前
django filter 排除字段
后端·python·django
卓越进步1 小时前
层级时间轮的 Golang 实现原理与实践
开发语言·后端·golang
古时的风筝1 小时前
Caddy 比Nginx 还优秀吗
前端·后端·程序员
古时的风筝1 小时前
Cursor 建议搭配 CursorRules 食用
前端·后端·cursor
网安刚哥2 小时前
雷池WAF的身份认证 - GitHub
后端
用户3414081991252 小时前
android的网络守护进程netd
后端
敲代码的瓦龙2 小时前
C++?动态内存管理!!!
c语言·开发语言·数据结构·c++·后端
陈唐其travel2 小时前
如何搭建自己的gitlab私有仓库
后端
雷渊2 小时前
深入分析dubbo的优雅停机
后端