达梦数据库闪回操作

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'
相关推荐
cjy0001111 小时前
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
java·spring boot·后端
小江的记录本2 小时前
【事务】Spring Framework核心——事务管理:ACID特性、隔离级别、传播行为、@Transactional底层原理、失效场景
java·数据库·分布式·后端·sql·spring·面试
sheji34162 小时前
【开题答辩全过程】以 基于springboot的校园失物招领系统为例,包含答辩的问题和答案
java·spring boot·后端
程序员cxuan3 小时前
人麻了,谁把我 ssh 干没了
人工智能·后端·程序员
wuyikeer4 小时前
Spring Framework 中文官方文档
java·后端·spring
Victor3564 小时前
MongoDB(61)如何避免大文档带来的性能问题?
后端
Victor3564 小时前
MongoDB(62)如何避免锁定问题?
后端
wuyikeer5 小时前
Spring BOOT 启动参数
java·spring boot·后端
子木HAPPY阳VIP6 小时前
Ubuntu 22.04 VMware 设置固定IP配置
人工智能·后端·目标检测·机器学习·目标跟踪
人间打气筒(Ada)6 小时前
如何基于 Go-kit 开发 Web 应用:从接口层到业务层再到数据层
开发语言·后端·golang