转自 http://blog.chinaunix.net/uid-8504518-id-3325718.html

今天开发人员问我如何快速并方便的查出一张表最近被更改的记录,这个需求很简单,由于是查最近被更改的数据,查回滚段就可以,下面是我做的小实验。

SQL> create table test(id number,name varchar2(10),gender varchar2(5));

表已创建。

SQL> insert into test values(1,'宋春风','男');  已创建 1 行。

SQL> insert into test values(2,'叶民','男');     已创建 1 行。

SQL> insert into test values(3,'白冰','男');     已创建 1 行。

SQL> insert into test values(4,'方巍森','男');  已创建 1 行。

SQL> insert into test values(5,'孙书祯','男');  已创建 1 行。

SQL> insert into test values(6,'史波','男');     已创建 1 行。

SQL> commit;                                            提交完成。

利用下面的SQL就可以查处最近更改的数据。

SQL> SELECT ID,NAME,VERSIONS_STARTTIME,VERSIONS_ENDTIME,VERSIONS_OPERATION

FROM TEST VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE WHERE

VERSIONS_STARTTIME IS NOT NULL ORDER BY VERSIONS_STARTTIME DESC;

ID NAME   GENDE VERSIONS_STARTTIME        VERSIONS_ENDTIME          V

---------- ------ ----- ------------------------- ------------------------- -

6 史波   男    30-11月-11 04.02.28 下午                            I

5 孙书祯 男    30-11月-11 04.02.28 下午                            I

1 宋春风 男    30-11月-11 04.02.28 下午                            I

3 白冰   男    30-11月-11 04.02.28 下午                            I

2 叶民   男    30-11月-11 04.02.28 下午                            I

4 方巍森 男    30-11月-11 04.02.28 下午                            I

已选择6行。

修改几条数据和接下来的查询做对比。

SQL> UPDATE TEST SET GENDER='女' WHERE NAME='孙书祯';     已更新 1 行。

SQL> COMMIT;      提交完成。

SQL> UPDATE TEST SET GENDER='女' WHERE NAME='史波';        已更新 1 行。

SQL> COMMIT;                                                                         提交完成。

再次查询,被修改的数据就可以看到被修改和修改前的数据。

SQL> SELECT ID,NAME,GENDER,VERSIONS_STARTTIME,VERSIONS_ENDTIME,

VERSIONS_OPERATION FROM TEST VERSIONS BETWEEN TIMESTAMP MINVALUE AND

MAXVALUE WHERE VERSIONS_STARTTIME IS NOT NULL ORDER BY

VERSIONS_STARTTIME DESC;

ID NAME   GENDE VERSIONS_STARTTIME        VERSIONS_ENDTIME          V

---------- ------ ----- ------------------------- ------------------------- -

6 史波   女    30-11月-11 04.15.07 下午                            U

5 孙书祯 女    30-11月-11 04.14.31 下午                            U

4 方巍森 男    30-11月-11 04.02.28 下午                            I

3 白冰   男    30-11月-11 04.02.28 下午                            I

2 叶民   男    30-11月-11 04.02.28 下午                            I

1 宋春风 男    30-11月-11 04.02.28 下午                            I

6 史波   男    30-11月-11 04.02.28 下午  30-11月-11 04.15.07 下午  I

5 孙书祯 男    30-11月-11 04.02.28 下午  30-11月-11 04.14.31 下午  I

已选择8行。

再修改几条数据后后查询。

SQL> delete from test WHERE NAME='史波';            已删除 1 行。

SQL> delete from test WHERE NAME='孙书祯';         已删除 1 行。

SQL> commit;                                                      提交完成。

SQL> SELECT ID,NAME,GENDER,VERSIONS_STARTTIME,VERSIONS_ENDTIME,

VERSIONS_OPERATION FROM TEST VERSIONS BETWEEN TIMESTAMP MINVALUE AND

MAXVALUE WHERE VERSIONS_STARTTIME IS NOT NULL ORDER BY

VERSIONS_STARTTIME DESC;

ID NAME   GENDE VERSIONS_STARTTIME        VERSIONS_ENDTIME          V

---------- ------ ----- ------------------------- ------------------------- -

5 孙书祯 男    30-11月-11 04.26.02 下午                            D

6 史波   男    30-11月-11 04.26.02 下午                            D

6 史波   女    30-11月-11 04.15.07 下午  30-11月-11 04.19.08 下午  U

5 孙书祯 女    30-11月-11 04.14.31 下午  30-11月-11 04.19.08 下午  U

2 叶民   男    30-11月-11 04.02.28 下午                            I

3 白冰   男    30-11月-11 04.02.28 下午                            I

4 方巍森 男    30-11月-11 04.02.28 下午                            I

5 孙书祯 男    30-11月-11 04.02.28 下午  30-11月-11 04.14.31 下午  I

1 宋春风 男    30-11月-11 04.02.28 下午                            I

6 史波   男    30-11月-11 04.02.28 下午  30-11月-11 04.15.07 下午  I

已选择10行。

通过以上小实验可以看出,VERSIONS_STARTTIME是数据被修改的起始时间,VERSIONS_ENDTIME是数据被修改后新数据的有效时间,也就是VERSIONS_STARTTIME和VERSIONS_ENDTIME时间段内,这条数据再没被修改过,如果VERSIONS_ENDTIME为空,就说明这天记录从VERSIONS_STARTTIME时间起再没被修改过。VERSIONS_OPERATION是修改状态,I代表INSERT,U代表UPDATE,D代表DELETE。此时如果想回滚INSERT的数据,只需要DELETE反向操作即可,如果想回滚UPDATE操作,将数据反向UPDATE回去即可,比如本实验已经可以看到进行UPDATE操作的是NAME为史波和孙书祯的两条记录,而且也可以看到进行UPDATE之前的数据他们的性别是男,所以只需要在做个反向UPDATE,将性别该为男即可实现回退,如果要回滚DELETE操作,同样做个INSERT操作,将删除的数据在插回去即可。

注:此SQL只能查询到回滚段内的信息,超出回滚段范围这个SQL就无能为力了,需要借助LOGMGR工具挖掘日志了(详见http://www.dbdream.org/?p=149)

ORACLE查询表最近更改的数据 VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE的更多相关文章

  1. ORACLE查询表最近更改数据的方法

    修改项目时,涉及到了Oracle中许多表的修改(包括:增加.删除字段,修改注释等).由于开始没有进行记录,造成在上测试机时,忘记了具体修改过哪些表了.后来在网上查找了一些资料,例如: 1.select ...

  2. Oracle 查询表中字段里数据是否有重复

    1.查找单个字段 select 字段名,count(*) from table group by 字段名 having count(*) > 1 2.查找组合字段: SELECT TEST_NA ...

  3. Oracle查询表里的重复数据方法:

    一.背景 一张person表,有id和name的两个字段,id是唯一的不允许重复,id相同则认为是重复的记录. 二.解决 select id from group by id having count ...

  4. oracle查询表数据并重新插入到本表

      oracle查询表数据并重新插入到本表 CreateTime--2018年5月17日10:30:10 Author:Marydon 1.情景描述 --查询表中数据 SELECT * FROM at ...

  5. 四、Oracle loop循环、while循环、for循环、if选择和case选择、更改读取数据、游标、触发器、存储过程

    数据库的设计(DataBase Design): 针对于用户特定的需求,然后我们创建出来一个最使用而且性能高的数据库! 数据库设计的步骤: 01.需求分析 02.概念结构设计 03.逻辑结构设计 04 ...

  6. 针对Oracle数据库表中的数据的常见操作

    1.查询表中所有数据 select * from 表名; 例:select * from stu; 2.查询的同时修改表中数据 select * from 表名  for update; 例:sele ...

  7. oracle 查询表名以及表的列名

    oracle 查询表名以及表的列名的代码.   1.查询表名: 代码如下: select table_name,tablespace_name,temporary from user_tables [ ...

  8. oracle 查询表的大小,表空间的使用情况,默认表空间

    oracle 查询表的大小,表空间的使用情况,默认表空间 oracle 查询表的大小,表空间的使用情况,默认表空间 --查看某张表占用磁盘空间大小 ( 表名大写 ) Select Segment_Na ...

  9. 类型:Oracle;问题:oracle 查询表详细信息;结果:oracle查询表信息(索引,外键,列等)

    oracle查询表信息(索引,外键,列等) oracle中查询表的信息,包括表名,字段名,字段类型,主键,外键唯一性约束信息,索引信息查询SQL如下,希望对大家有所帮助: 1.查询出所有的用户表sel ...

随机推荐

  1. 剑指offer六十之按之把二叉树打印成多行

    一.题目 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行.二.思路 队列LinkedList完成层序遍历,用end记录每层结点数目 三.代码 import java.util.Arra ...

  2. (转)linux如何让历史记录不记录敏感命令

    有时候为了服务器安全,防止别人窥探我们输入的命令,我们可以清空历史记录,而更多的时候,我们选择的是在输入特殊命令时候,强制历史记录不记住该命令.实验方法:先执行export HISTCONTROL=i ...

  3. EF基础知识小记三(设计器=>数据库)

    本文主要介绍通过EF的设计器来同步数据库和对应的实体类.并使用生成的实体上下文,来进行简单的增删查该操作 1.通过EF设计器创建一个简单模型 (1).右键目标项目添加新建项 (2).选择ADO.Net ...

  4. Linux文件目录管理

    Linux文件目录管理 文件的路径 路径: . 表示当此层目录 .. 表示上一层目录 - 代表前一个工作目录 ~ 代表"目前用户身份"所在的文件夹 ~account 代表accou ...

  5. 第6章—渲染web视图—使用Apache Tiles视图定义布局

    使用Apache Tiles视图定义布局   Tiles是一个免费的开源模板Java应用程序的框架.基于复合模式简化的用户界面的构建.对于复杂的网站仍是最简单.最优雅的方式与任何MVC技术一起工作.S ...

  6. 【链表】Insertion Sort List

    题目: Sort a linked list using insertion sort. 思路: 插入排序是一种O(n^2)复杂度的算法,基本想法相信大家都比较了解,就是每次循环找到一个元素在当前排好 ...

  7. docker 微镜像-alpine

    刚想找maven自动发布项目到tomcat, 突然看到个好玩的, docker微镜像 -- alpine 直接粘一段: Alpine Linux Docker镜像基于Alpine Linux操作系统, ...

  8. java NIO系列教程1

    ava NIO(New IO)是一个可以替代标准Java IO API的IO API(从Java 1.4开始),Java NIO提供了与标准IO不同的IO工作方式. Java NIO: Channel ...

  9. Node.js之Express二

    好久没写了,今天看博客,觉得有必要把node.js继续写完,善始善终.原本想着把小崔课堂继续讲下去,由于其他原因也就此耽搁下来,看看以后还有没有机会吧.废话不扯,123开始. 一.Exoress之Re ...

  10. 12.Reflect

    Reflect Reflect 概述 Reflect对象与Proxy对象一样,也是 ES6 为了操作对象而提供的新 API.Reflect对象的设计目的有这样几个. (1) 将Object对象的一些明 ...