有数据库备份吗
如果有exp备份,可以通过imp导入恢复表数据
如果有rman备份,可以把数据库按时间恢复到测试备库,然后在导会本库
如果没有备份,可以尝试使用logmnr挖掘在线日志或归档日志,生成一些表的一些数据
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 执行这个操作.
第一段:如果是刚刚删除,那么有两方法:
首先用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
-开启行移动功能
alter table 表名 enable row movement;
--恢复表数据
上述时间为删除数据的时间
备注:恢复后请关闭行移动功能
以上就是土嘎嘎小编为大家整理的oracle怎么修复表相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!