Oracle数据库中对误删数据的快速恢复「建议收藏」

Oracle数据库中对误删数据的快速恢复「建议收藏」采用闪回技术对误删除的数据进行恢复。

大家好,又见面了,我是你们的朋友全栈君。

如果一不小心对Oracle数据库中的数据进行了误删除操作,那么如何进行数据恢复呢(不考虑全库备份和利用归档日志)?如果使用的是9i以及之后的版本,那么我们可以采用闪回技术对误删除的数据进行恢复。方式有两种。

原理:
利用oracle提供的闪回方法,如果在删除数据后还没做大量的操作(只要保证被删除数据的块没被覆写),就可以利用闪回方式直接找回删除的数据。

*确定删除数据的时间(在删除数据之前的时间就行,不过最好是删除数据的时间点)。
*用语句找出删除的数据。
*把删除的数据重新插入原表。

方式1:基于时间戳的数据恢复 as of timestamp

1、首先要查询到系统的当前时间,必须以系统时间的时间戳为基准。

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual;

2、查询当前系统时间20分钟前的数据。SYSDATE是系统函数,用来取得当前的系统时间(以天为单位),SYSDATE-20/1440,得出的就是距当前时间20分钟前的记录了(60*24=1440)。

select * from 表名 as of timestamp sysdate-20/1440;

3、将20分钟前的数据重新插回表中(注意不要存在相同的主键)。由于在时间上的不准确,可能会导致恢复的数据中包括了一些已经在表中的数据。这就会引起主键不唯一的冲突,为了避免这样冲突,建议将步骤2的数据恢复到新表中。

**恢复到原来的表**
insert into 表名 (select * from 表名 as of timestamp sysdate-20/1440 );

**恢复到新表**
create table 新表名
as select * from 误操作的表
as of timestamp sysdate-20/1440 ;时间点

注意:
AS OF TIMESTAMP方式的使用非常方便,但是在某些情况下,我们建议使用AS OF SCN的方式执行Flashback Query。如需要对多个相互有主外键约束的表进行恢复时,如果使用AS OF TIMESTAMP的方式,可能会由于时间点不统一的缘故造成数据选择或插入失败,通过AS OF SCN方式则能够确保记录处理的时间点一致。

方式2:基于SCN的数据恢复 as of scn

1、获得当前数据库的scn号,查询到的scn号为:1499223

 select current_scn from v$database; (切换到sys用户或system用户查询) 

2、查询当前scn号之前的scn

select * from 表名 as of scn 1499220; (确定删除的数据是否存在,如果存在,则恢复数据;如果不是,则继续缩小scn号)

3、恢复删除且已提交的数据

flashback table 表名 to scn 1499220;

参考链接

  • http://www.cnblogs.com/kangxuebin/archive/2013/05/29/3106183.html
  • http://www.cnblogs.com/hqbhonker/p/3977200.html
  • http://blog.csdn.net/itdada/article/details/52746392
  • http://blog.csdn.net/zhouwubin123/article/details/6617837
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/160793.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • redis远程连接不上解决办法「建议收藏」

    redis远程连接不上解决办法「建议收藏」问题描述:redis远程服务端运行在192.168.3.90计算机上,客户端计算机(ip:192.168.3.110)通过redsi-cli.exe客户端工具连接时,没有反应,连接不上。如图所示:解决步骤:步骤一:注释掉redis.window.conf文件中的bind属性设置。如图所示:步骤二:把protected-mode属性设置no…

    2022年9月19日
    0
  • 函数类型_C语言函数类型

    函数类型_C语言函数类型函数类型在ECMAScript中有三种函数类型:函数声明,函数表达式和函数构造器创建的函数。每一种都有自己的特点。1.函数声明这种函数类型的主要特点在于它们仅仅影响变量对象。该特点也解释了第二

    2022年8月5日
    2
  • android之View坐标系(view获取自身坐标的方法和点击事件中坐标的获取)

    在做一个view背景特效的时候被坐标的各个获取方法搞晕了,几篇抄来抄去的博客也没弄很清楚。现在把整个总结一下。其实只要把下面这张图看明白就没问题了。涉及到的方法一共有下面几个:view获取自身坐标:getLeft(),getTop(),getRight(),getBottom()view获取自身宽高:getHeight(),getWidth()motionEvent获取坐标:getX(),getY

    2022年3月11日
    57
  • 子组件传对象给父组件_react子组件改变父组件的状态

    子组件传对象给父组件_react子组件改变父组件的状态子组件传值给父组件首先子组件(组件名“Child”)内定义一个方法例如sendData=()=>{letdata=‘1234’;this.props.getData(data);//这个this,props.xxx后面的xxx是是在父组件那使用的名字;},然后可以在render函数后使用这个方法或者另外定义一个事件去触发该方法进行传值,之后可在父组件(Parent)内使用这个方法获取拿到的值:Parent组件内:首先定义一个方法getData或者其他什么都可以随

    2022年9月5日
    2
  • java基础编程入门教程,2022最新

    java基础编程入门教程,2022最新Java学习到什么程度可以找第一份工作自己买了本Java从入门到精通。以为可以很快地学完,非CS专业。现在我想说所有系列的从入门到精通都是垃圾,一年多来,我每天白天看视频,晚上敲代码到凌晨,我是一个很倔的人,我认为天下没有任何东西是人类学不会的,所以我就付出高三一样的时间去学习。为你解读Java三大框架其实作为Java初学者除了简单的学习框架本身,还需要思考更多的东西,比如有框架和没有框架到底给你带来了什么?用Struts,要充分的理解MVC思想,用Hibernate,要明白什么是持久化,什么是OR/m

    2022年7月9日
    18
  • excel表格如何查重_if函数多列查重

    excel表格如何查重_if函数多列查重学习了excel函数:countif。表达式:COUNTIF(数据区域,条件),作用:对数据区域内符合条件单元格计数具体应用在“姓名”(列A)后插入一列(列B),在B2单元格输入公式“=IF(COUN

    2022年8月1日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号