oracle闪回版本查询

闪回版本查询(Flashback Versions Query)是Oracle数据库提供的一种功能,允许用户查看某个表在特定时间范围内的所有版本。这对于审计和调试数据修改问题非常有用。通过闪回版本查询,你可以了解表中的数据在某个时间段内的变化历史。

实例代码

css 复制代码
CREATE TABLE employees (
  employee_id NUMBER PRIMARY KEY,
  first_name VARCHAR2(50),
  last_name VARCHAR2(50),
  salary NUMBER
);

-- 插入一些数据
INSERT INTO employees VALUES (1, 'John', 'Doe', 5000);
INSERT INTO employees VALUES (2, 'Jane', 'Smith', 6000);
COMMIT;

-- 更新数据
UPDATE employees SET salary = 5500 WHERE employee_id = 1;
COMMIT;

-- 删除数据
DELETE FROM employees WHERE employee_id = 2;
COMMIT;



select * from employees

-- 插入一些数据
INSERT INTO employees VALUES (5, 'John', 'Doe', 5000);
INSERT INTO employees VALUES (6, 'Jane', 'Smith', 6000);
commit;

上述代码经历了创建表,更新表相关的操作;

sql 复制代码
select * from 表  VERSIONS BETWEEN  scn minvalue and maxvalue

VERSIONS BETWEEN选择版本闪回的区间,可以根据实际情况而定。

sql 复制代码
SELECT versions_starttime, versions_endtime, versions_xid, versions_operation, employee_id, first_name, last_name, salary
FROM employees VERSIONS BETWEEN scn minvalue and maxvalue

上图中可以查看到表每次操作后生成新版本表变化情况。

相关推荐
zbguolei5 小时前
上传 Excel 文件进行数据库比对--增加导出功能
数据库·excel
amao99885 小时前
数据库原理与技术 - 3-7 视图和索引 View& Index
数据库·sql·oracle
酸菜牛肉汤面5 小时前
30、大表数据查询,怎么优化
数据库
KG_LLM图谱增强大模型5 小时前
企业级实用本体论的实践指南(2/4):Palantir Foundry如何将组织数据映射到本体概念及关键设计考量
数据库·人工智能
陌路206 小时前
redis智能缓存策略--思想
数据库·redis·缓存
计算机毕设VX:Fegn08956 小时前
计算机毕业设计|基于springboot + vue出行旅游安排系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·课程设计
一只大黄猫6 小时前
【数据库-入门3】基本概念
数据库
@海~涛6 小时前
AOSP源码下载与编译
android·数据库·缓存·安卓·安全架构
五阿哥永琪6 小时前
MySQL 如何定位&分析慢查询?
android·数据库·mysql
柒.梧.6 小时前
从原理到实战:Spring AOP全解析
数据库·sql