Oracle查看表操作历史记录并恢复数据的方法
作者:凌霄玉阶非所愿
Oracle是一种广泛应用于企业级数据库系统的软件,但在操作过程中可能会发生误删除数据的情况,这时就需要进行数据恢复操作,这篇文章主要给大家介绍了关于Oracle查看表操作历史记录并恢复数据的相关资料,需要的朋友可以参考下
一、查找表操作记录
1.首先查找表操作的历史记录 select * from v$sqlarea a where a.SQL_TEXT like '%表名%'; 2.从上面的记录中找到update语句对应的sql_id select * from v$sqltext a,v$sqlarea b where a.SQL_ID=b.SQL_ID and b.SQL_ID in('cq53826tk4u3c','afftnrfhu5utk') order by b.LAST_ACTIVE_TIME desc; 3.从上面的记录中找到最新的sql操作记录,然后找到用户名和主机 select * from sys.v_$session l,sys.v_$sql s where s.SQL_ID='cq53826tk4u3c' and l.USERNAME is not null;
二、恢复数据
//1.根据时间恢复 //示例: select * from t_noentryquery; delete from t_noentryquery where fid=7369; //查询当前电脑时间: select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')from dual; //查询删除之前数据: select * from t_noentryquery as of timestamp to_timestamp('2018-04-12 09:12:11','yyyy-mm-dd hh24:mi:ss'); //恢复数据: flashback table t_noentryquery to timestamp to_timestamp('2018-04-12 09:12:11','yyyy-mm-dd hh24:mi:ss'); //注意:若出现报错:ORA-08189:未启用行移动功能,不能闪回表; //则: alter table t_noentryquery enable row movement; //开启行移动功能 alter table t_noentryquery disable row movement; //关闭行移动功能
附:oracle查询表最近更改的数据
查看一张最近被更改的记录,可以查回滚段,下面是一个例子:
create table test(id number,name varchar2(10),gender varchar2(5)); insert into test values(1,'宋春风','男'); insert into test values(2,'叶民','男'); insert into test values(3,'白冰','男'); insert into test values(4,'方巍森','男'); insert into test values(5,'孙书祯','男'); insert into test values(6,'史波','男'); commit;
利用下面的SQL可以查询最近更改的数据。
SELECT * FROM TEST VERSIONS BETWEEN TIMESTAMP MINVALUE AND MAXVALUE WHERE VERSIONS_STARTTIME IS NOT NULL ORDER BY VERSIONS_STARTTIME DESC;
修改几条数据和接下来的查询做对比。
UPDATE TEST SET GENDER='女' WHERE NAME='孙书祯'; UPDATE TEST SET GENDER='女' WHERE NAME='史波'; commit;
再次查询,被修改的数据就可以看到被修改和修改前的数据。
总结:VERSIONS_STARTTIME是数据被修改的起始时间,VERSIONS_ENDTIME是数据被修改后新数据的有效时间,也就是VERSIONS_STARTTIME和VERSIONS_ENDTIME时间段内,这条数据再没被修改过,如果VERSIONS_ENDTIME为空,就说明这条记录从VERSIONS_STARTTIME时间起再没被修改过。VERSIONS_OPERATION是修改状态,I代表INSERT,U代表UPDATE,D代表DELETE。此时
如果想回滚INSERT的数据,只需要DELETE反向操作即可,如果想回滚UPDATE操作,将数据反向UPDATE回去即可。
注:此SQL只能查询到回滚段内的信息,超出回滚段范围这个SQL就无能为力了,需要借助LOGMGR工具挖掘日志了。
总结
到此这篇关于Oracle查看表操作历史记录并恢复数据的文章就介绍到这了,更多相关Oracle查看表操作历史记录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!