• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle误删除表数据后的恢复详解

mysql 搞代码 4年前 (2022-01-09) 34次浏览 已收录 0个评论

一、undo_retention参数的查询、修改:用show parameter undo;命令查看当时的数据库参数undo_retention设置。显示如下:undo_man

一、undo_retention参数的查询、修改:

用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 SYST

本文来源gao!%daima.com搞$代*!码网1

EM SET undo_retention=10800 SCOPE=BOTH;

二、Oracle误删除表数据后的的快速恢复功能方法:

【方法一】:
通过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;
这种办法可以将删除的数据恢复到对应的表中,首先要保证该用户有执行dbms_flashback包的权限

【方法二】:
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> col fscn for 9999999999999999999SQL> col nscn for 9999999999999999999SQL> select name,FIRST_CHANGE# fscn,NEXT_CHANGE# nscn,FIRST_TIME from v$archived_log;……………….NAMEFSCNNSCN FIRST_TIME—————————— ——————– ——————– ——————-/mwarch/oracle/1_52413.dbf1292994196812929942881 2005-06-22 14:38:28/mwarch/oracle/1_52414.dbf1292994288112929943706 2005-06-22 14:38:32/mwarch/oracle/1_52415.dbf1292994370612929944623 2005-06-22 14:38:35/mwarch/oracle/1_52416.dbf1292994462312929945392 2005-06-22 14:38:38/mwarch/oracle/1_52417.dbf1292994539212929945888 2005-06-22 14:38:41/mwarch/oracle/1_52418.dbf1292994588812929945965 2005-06-22 14:38:44/mwarch/oracle/1_52419.dbf1292994596512929948945 2005-06-22 14:38:45/mwarch/oracle/1_52420.dbf1292994894512929949904 2005-06-22 14:46:05/mwarch/oracle/1_52421.dbf1292994990412929950854 2005-06-22 14:46:08/mwarch/oracle/1_52422.dbf1292995085412929951751 2005-06-22 14:46:11/mwarch/oracle/1_52423.dbf1292995175112929952587 2005-06-22 14:46:14………………./mwarch/oracle/1_52498.dbf1293013897512930139212 2005-06-22 15:55:57/mwarch/oracle/1_52499.dbf1293013921212930139446 2005-06-22 15:55:59/mwarch/oracle/1_52500.dbf1293013944612930139682 2005-06-22 15:56:00NAMEFSCNNSCN FIRST_TIME—————————— ——————– ——————– ——————-/mwarch/oracle/1_52501.dbf1293013968212930139915 2005-06-22 15:56:02/mwarch/oracle/1_52502.dbf1293013991512930140149 2005-06-22 15:56:03/mwarch/oracle/1_52503.dbf1293014014912930140379 2005-06-22 15:56:05/mwarch/oracle/1_52504.dbf1293014037912930140610 2005-06-22 15:56:05/mwarch/oracle/1_52505.dbf1293014061012930140845 2005-06-22 15:56:0714811 rows selected.


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle误删除表数据后的恢复详解
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址