达梦数据库闪回操作

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'
相关推荐
JustHappy6 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
Hommy886 小时前
【剪映小助手】添加图片接口(Add Images)
后端·github·剪映小助手·视频剪辑自动化
GetcharZp7 小时前
别再盲目用 OpenCV 读图了,这才是 CV 预处理的终极杀手锏!
后端
IT_陈寒10 小时前
Vite热更新失效?可能你在用Windows
前端·人工智能·后端
椰椰椰耶12 小时前
[SpringCloud][14]OpenFeign参数传递方法
后端·spring·spring cloud
onething36512 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 3 —— 消息表设计 + 级联删除 + 事务管理
人工智能·后端
荣江12 小时前
Hermes Agent 代码仓库打包工具使用指南(repomix-rs 高性能版)
后端
王某某人12 小时前
LangChain4j 入门:Java 程序员的第一个 AI 对话程序
人工智能·后端
码农刚子12 小时前
从零开始:在 Windows 服务器上部署 Node.js 项目(小白实战教程)
后端·node.js
Cache技术分享12 小时前
435. Java 日期时间 API - Clock 灵活获取当前时间
前端·后端