Oracle查看表操作历史记录并恢复数据的方法

 更新时间:2023年08月10日 09:28:23   作者:凌霄玉阶非所愿  
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查看表操作历史记录内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • oracle中误删除表后恢复语句(FLASHBACK)

    oracle中误删除表后恢复语句(FLASHBACK)

    在操作过程中难免会误操作,出现这种情况应该怎样解决呢?不要着急,下面与大家分享下误删的恢复语句
    2013-06-06
  • Oracle中分组查询group by用法规则详解

    Oracle中分组查询group by用法规则详解

    这篇文章主要介绍了Oracle中分组查询group by用法规则详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Oracle查询实例之订单金额占比与排名分析

    Oracle查询实例之订单金额占比与排名分析

    这篇文章主要介绍了Oracle查询实例之订单金额占比与排名分析的相关资料,文中通过代码介绍了两种方法来查询每个客户在每个日期的订单金额、占比以及排名,需要的朋友可以参考下
    2025-11-11
  • 详解Oracle游标的简易用法

    详解Oracle游标的简易用法

    这篇文章主要介绍了详解Oracle游标的简易用法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • oracle中使用in和not in查询效率总结和优化建议

    oracle中使用in和not in查询效率总结和优化建议

    oracle的sql语句中的in和not in是自动将字段为null的去掉了,下面这篇文章主要介绍了oracle中使用in和not in查询效率总结和优化建议的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-11-11
  • Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理

    Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理

    Linux系统下导出ORACLE数据库出现Exporting questionable statistics.错误 处理...
    2007-03-03
  • 如何使用log miner分析oracle日志

    如何使用log miner分析oracle日志

    日常生活中,我们经常因为操作失误丢失数据或者是更改数据,如何进行恢复呐?这篇文章就是帮助我们解决这一困扰,需要的朋友可以参考下
    2015-07-07
  • Oracle常见分析函数实例详解

    Oracle常见分析函数实例详解

    分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计,下面这篇文章主要给大家介绍了关于Oracle常见分析函数的相关资料,需要的朋友可以参考下
    2023-04-04
  • 如何使用Navicat Premium连接Oracle数据库

    如何使用Navicat Premium连接Oracle数据库

    这篇文章主要介绍了如何使用Navicat Premium连接Oracle数据库,需要的朋友可以参考下
    2023-01-01
  • Oracle登录时忘记用户名或密码该如何解决

    Oracle登录时忘记用户名或密码该如何解决

    这篇文章主要介绍了如何在Oracle 12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参考借鉴价值,需要的朋友可以参考下
    2025-03-03

最新评论