oracle误删数据表还原的二种方法(oracle还原)

前端之家收集整理的这篇文章主要介绍了oracle误删数据表还原的二种方法(oracle还原)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

@H_403_0@一、如果是刚刚删除,那么有两方法


@H_403_0@首先用show parameter undo;命令查看当时的数据库参数undoretention设置。


@H
403_0@显示如下:
<div class="codetitle"><a style="CURSOR: pointer" data="62913" class="copybut" id="copybut62913" onclick="doCopy('code62913')"> 代码如下:
<div class="codebody" id="code62913">
undomanagement string AUTO


@H
403_0@undoretention integer 10800


@H
403_0@undo_suppresserrors boolean FALSE


@H
403_0@undotablespace string UNDOTBS1


@H
403_0@undoretention(保持力),10800单位是秒。即3个小时。


@H
403_0@修改默认的undoretention参数设置:


@H
403_0@<div class="codetitle"><a style="CURSOR: pointer" data="54627" class="copybut" id="copybut54627" onclick="doCopy('code54627')"> 代码如下:
<div class="codebody" id="code54627">
ALTER SYSTEM SET undoretention=10800 SCOPE=BOTH;


@H
403_0@方法1,通过oracle提供的回闪功能
<div class="codetitle"><a style="CURSOR: pointer" data="32600" class="copybut" id="copybut32600" onclick="doCopy('code32600')"> 代码如下:
<div class="codebody" id="code32600">
exec dbms_flashback.enable_at_time(todate('2007-07-23 10:21:00','yyyy-mm-dd hh24:mi:ss'));


@H
4030@set serveroutput on


@H
403_0@DECLARE r_temp hr.jobhistory%ROWTYPE;


@H
403_0@CURSOR c_temp IS SELECT FROM hr.jobhistory;


@H
4030@BEGIN


@H
403_0@OPEN ctemp;


@H
403_0@dbmsflashback.disable;


@H
4030@LOOP


@H
403_0@FETCH c_temp INTO rtemp;


@H
403_0@EXIT WHEN ctemp%NOTFOUND;


@H
403_0@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.ENDDATE);


@H
4030@commit;


@H
4030@END LOOP;


@H
403_0@CLOSE ctemp;


@H
4030@END;


@H
403_0@方法2,insert into hr.jobhistory


@H
403_0@<div class="codetitle"><a style="CURSOR: pointer" data="72121" class="copybut" id="copybut72121" onclick="doCopy('code72121')"> 代码如下:
<div class="codebody" id="code72121">
select
from hr.job_history as of timestamp totimestamp('2007-07-23 10:20:00','yyyy-mm-dd hh24:mi:ss');


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


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


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


@H_403_0@四、恢复到备份表中
<div class="codetitle"><a style="CURSOR: pointer" data="53559" class="copybut" id="copybut53559" onclick="doCopy('code53559')"> 代码如下:<div class="codebody" id="code53559">
create table tableName_bak
as
select * from tableName as of TIMESTAMP to_timestamp('20081126 103435','yyyymmdd hh24miss');

原文链接:https://www.f2er.com/oracle/65396.html
oracleoracleoracle还原误删数据

猜你在找的Oracle相关文章