oracle

推荐列表 站点导航

当前位置:首页 > 数据库 > oracle >

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

来源:网络整理  作者:网络  发布时间:2020-12-08 23:31
这篇文章主要介绍了oracle误删数据表还原的二种方法,大家参考使用吧...

修改默认的undo_retention参数设置:

复制代码 代码如下:

LOOP


set serveroutput on

END;

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

as

四、恢复到备份表中

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);

select * from hr.job_history as of timestamp to_timestamp('2007-07-23 10:20:00', 'yyyy-mm-dd hh24:mi:ss');

CURSOR c_temp IS SELECT * FROM hr.job_history;

undo_tablespace   string   UNDOTBS1


CLOSE c_temp;

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

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

EXIT WHEN c_temp%NOTFOUND;

select * from tableName as of TIMESTAMP to_timestamp('20081126 103435','yyyymmdd hh24miss');

DECLARE r_temp hr.job_history%ROWTYPE;


dbms_flashback.disable;

END LOOP;

OPEN c_temp;

复制代码 代码如下:

BEGIN

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

commit;

create table tableName_bak

FETCH c_temp INTO r_temp;

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

方法2,insert into hr.job_history

exec dbms_flashback.enable_at_time(to_date('2007-07-23 10:21:00','yyyy-mm-dd hh24:mi:ss'));

复制代码 代码如下:

undo_retention(保持力),10800单位是秒。即3个小时。

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

复制代码 代码如下:


undo_management   string   AUTO

ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;

显示如下:

undo_suppress_errors  boolean  FALSE

复制代码 代码如下:


undo_retention  integer 10800

相关热词: oracle 方法

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://www.juheyunku.com/sql/oracle/1594.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

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

2020-12-08 编辑:网络

修改默认的undo_retention参数设置:

复制代码 代码如下:

LOOP


set serveroutput on

END;

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

as

四、恢复到备份表中

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);

select * from hr.job_history as of timestamp to_timestamp('2007-07-23 10:20:00', 'yyyy-mm-dd hh24:mi:ss');

CURSOR c_temp IS SELECT * FROM hr.job_history;

undo_tablespace   string   UNDOTBS1


CLOSE c_temp;

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

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

EXIT WHEN c_temp%NOTFOUND;

select * from tableName as of TIMESTAMP to_timestamp('20081126 103435','yyyymmdd hh24miss');

DECLARE r_temp hr.job_history%ROWTYPE;


dbms_flashback.disable;

END LOOP;

OPEN c_temp;

复制代码 代码如下:

BEGIN

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

commit;

create table tableName_bak

FETCH c_temp INTO r_temp;

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

方法2,insert into hr.job_history

exec dbms_flashback.enable_at_time(to_date('2007-07-23 10:21:00','yyyy-mm-dd hh24:mi:ss'));

复制代码 代码如下:

undo_retention(保持力),10800单位是秒。即3个小时。

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

复制代码 代码如下:


undo_management   string   AUTO

ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;

显示如下:

undo_suppress_errors  boolean  FALSE

复制代码 代码如下:


undo_retention  integer 10800

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://www.juheyunku.com/sql/oracle/1594.shtml

相关文章

风云图片

推荐阅读

返回oracle频道首页