当前位置:首页 > 正文

oracle删表怎么恢复_oracle删除表怎么恢复

更新时间:2025-01-24 08:43 阅读量:38009

oracle如何恢复误删的表记录数据?

oracle如何恢复误删的表记录数据,解决办法:

从flash back里查询被删除的表select * from recyclebin

执行表的恢复flashback table ?tbName ?to before drop;这里的tbName代表你要恢复的表的名称.

先从flashback_transaction_query视图里查询,视图提供了供查询用的表名称、事务提交时间、UNDO_SQL等字段.

这个命令的作用是,允许Oracle 修改分配给行的rowid.

在Oracle 中,插入一行时就会为它分配一个rowid,而且这一行永远拥有这个rowid.

闪回表处理会对EMP 完成DELETE,并且重新插入行,这样就会为这些行分配一个新的rowid.

要支持闪回就必须允许Oracle 执行这个操作.

在oracle中如何找回被删除的数据?

①.、首先新建一张测试表TEST,里面输入记录.由于删除/更新/插入恢复步骤相同,这里仅演示删除数据的情况.

SELECT *

可以看到报错了,原因是没有开启行移动.

ALTER TABLE TEST ENABLE ROW MOVEMENT;

然后查看数据情况,可以看到已经恢复了.

oracle 误删除表的几种恢复方法

误删数据(delete)的话,可以在undo空间找到最近的数据(根oracle设置的undo大小有关)一般刚删除的还是有机会找到的,自己根据SQL修改时间饥渴

SELECT?*

WHERE?可以带条件;

如果是误删表(drop)的话.需要在回收站是否启用,查看回收站中表

select?object_name,original_name,partition_name,type,ts_name,createtime,droptime?from?recyclebin;

flashback?table?表名?to?before?drop;

--或

中间这一串BIN...... 是在回收站表中找到对应的名字

oracle中怎样将删除的表找回来

从Oracle10g开始提供了flashback drop的功能.

而在以前的版本中,除了不完全恢复,通常没有一个好的解决办法.

Oracle 10g的flashback drop功能,允许你从当前数据库中恢复一个被drop了的对象,在执行drop操作时,现在Oracle不是真正删除它,而是将该对象自动将放入回收站.对于一个对象的删除,其实仅仅就是简单的重命名操作.

所以如果你用的是10G,并且没有关闭flashback drop功能,就可以找回删除的表.

如果你用的不是10G,或者关闭了flashback drop功能,

只能看看你之前有没有做备份,如果有可以恢复一下

回收站内的oracle删表怎么恢复相关咨询可以从recyclebin/user_recyclebin/dba_recyclebin等视图中获取,或者通过SQL*Plus的show recyclebin 命令查看.

oracle数据库删除错了表怎么恢复

第一段:如果是刚刚删除,那么有两方法:

首先用show parameter undo;命令查看当时的数据库参数undo_retention设置.

显示如下:

undo_management?string?AUTO

undo_suppress_errors?boolean?FALSE

undo_tablespace?string?UNDOTBS1

修改默认的undo_retention参数设置:

方法1,通过oracle提供的回闪功能:

set?serveroutput?on

DECLARE?r_temp?hr.job_history%ROWTYPE;

CURSOR?c_temp?IS?SELECT?*?FROM?hr.job_history;

BEGIN

OPEN?c_temp;

dbms_flashback.disable;

LOOP

FETCH?c_temp?INTO?r_temp;

EXIT?WHEN?c_temp%NOTFOUND;

insert?into?hr.job_history(EMPLOYEE_ID,JOB_ID,START_DATE,END_DATE)?values?(r_temp.EMPLOYEE_ID,r_temp.JOB_ID,r_temp.START_DATE,r_temp.END_DATE);

commit;

END?LOOP;

CLOSE?c_temp;

END;

这种方法简单,容易掌握,功能和上面的一样时间为你误操作之前的时间,最好是离误操作比较近的,因为oracle保存在回滚保持段里的数据时间有一定的时间限制由undo_retention 这个参数值决定.

第二段:如果是删除一段时间了,但你有比较新的数据库备份,就通过备份来恢复.新建一个库,把备份还原上去,导出表数据,再导入到现在用的库中去.

第三段:如果删除一段时间了,并且无备份,但是数据在写入表的时候同时会写入其它一些关联表的话,那么就尝试通过写SQL语句从其它表取数据出来insert到被删除的表中.

第四段:恢复到备份表中

create?table?tableName_bak

as

oracle中表被删除怎么恢复

-开启行移动功能

alter table 表名 enable row movement;

--恢复表数据

上述时间为删除数据的时间

备注:恢复后请关闭行移动功能

以上就是新野小常识小编为大家整理的oracle删表怎么恢复相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!