加入收藏 | 设为首页 | 会员中心 | 我要投稿 通化站长网 (https://www.0435zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

oracle误删数据表还原的二种技巧

发布时间:2021-12-01 18:55:23 所属栏目:教程 来源:互联网
导读:一、如果是刚刚删除,那么有两方法: 首先用show parameter undo;命令查看当时的数据库参数undo_retention设置。 显示如下: 复制代码 代码如下: undo_management string AUTO undo_retention integer 10800 undo_suppress_errors boolean FALSE undo_tables

一、如果是刚刚删除,那么有两方法:
 
首先用show parameter undo;命令查看当时的数据库参数undo_retention设置。
 
显示如下:
 
复制代码 代码如下:
 
 
undo_management   string   AUTO
 
undo_retention  integer 10800
 
undo_suppress_errors  boolean  FALSE
 
undo_tablespace   string   UNDOTBS1
 
undo_retention(保持力),10800单位是秒。即3个小时。
 
修改默认的undo_retention参数设置:
 
复制代码 代码如下:
 
 
ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;
 
方法1,通过oracle提供的回闪功能:
 
复制代码 代码如下:
 
 
exec dbms_flashback.enable_at_time(to_date('2007-07-23 10:21:00','yyyy-mm-dd hh24:mi:ss'));
 
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;
 
方法2,insert into hr.job_history
 
复制代码 代码如下:
 
 
select * from hr.job_history as of timestamp to_timestamp('2007-07-23 10:20:00', 'yyyy-mm-dd hh24:mi:ss');
 
这种方法简单,容易掌握,功能和上面的一样时间为你误操作之前的时间,最好是离误操作比较近的,因为oracle保存在回滚保持段里的数据时间有一定的时间限制由undo_retention 这个参数值决定。
 
二、如果是删除一段时间了,但你有比较新的数据库备份,就通过备份来恢复。新建一个库,把备份还原上去,导出表数据,再导入到现在用的库中去。
 
三、如果删除一段时间了,并且无备份,但是数据在写入表的时候同时会写入其它一些关联表的话,那么就尝试通过写SQL语句从其它表取数据出来insert到被删除的表中。
 
四、恢复到备份表中
 
复制代码 代码如下:
 
 
create table tableName_bak
as
select * from tableName as of TIMESTAMP to_timestamp('20081126 103435','yyyymmdd hh24miss');

(编辑:通化站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!