快捷搜索:

ORACLE误删数据的恢复

有很多缘故原由导致了数据记录的误删,如何规复误删的记录呢?先来看看这个观点:

SCN(系统改变号),它的英文全拼为:System Change Number ,它是数据库中异常紧张的一个数据布局。

SCN供给了Oracle的内部时钟机制,可被看作逻辑时钟,这对付规复操作是至关紧张的

注释:Oracle 仅根据 SCN 履行规复。

它定义了数据库在某个确切时候提交的版本。在事物提交时,它被付与一个独一的标示事物的SCN 。一些人觉得 SCN 是指, System Commit Number ,而平日 SCN 在提交时才变更,以是很多环境下,

这两个名词常常被交替应用。

究竟是哪个词着实对我们来说并不是最紧张的,紧张的是我们知道 SCN 是 Oracle 内部的时钟机制, Oracle 经由过程 SCN 来掩护数据库的同等性,并经由过程SCN 实施 Oracle 至关紧张的规复机制。

详细履行流程我们可从以下几个示例图中体会;

1.原表记录 $ sqlplus eygle/eygle

SQL*Plus: Release 10.1.0.2.0 - Production on Wed Mar 30 08:52:04 2005

Copyright (c) 1982, 2004, Oracle.All rights reserved.

Connected to:

Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 - 64bit Production

With the Partitioning, OLAP and Data Mining options

SQL>select count(*) from t1;

COUNT(*)

----------

9318

2.误删除所有记录

并且提交变动。

SQL>delete from t1;

9318 rows deleted.

SQL>commit;

Commit complete.

SQL>select count(*) from t1;

COUNT(*)

----------

0

3.获适合前SCN

假如能够确切知道删除之前SCN最好,假如不知道,可以进行闪回查询考试测验.

SQL>select dbms_flashback.get_system_change_number from dual;

GET_SYSTEM_CHANGE_NUMBER

------------------------

10671006

SQL>select count(*) from t1 as of scn 10671000;

COUNT(*)

----------

0

SQL>select count(*) from t1 as of scn 10670000;

COUNT(*)

----------

9318

我们看到在SCN=10670000时,数据都在。

4.规复数据.

SQL>insert into t1 select * from t1 as of scn 10670000;

9318 rows created.

SQL>commit;

Commit complete.

SQL>select count(*) from t1;

COUNT(*)

----------

9318

文章2

误删数据后的还原

select timestamp_to_scn(to_timestamp('2009-03-13 09:00:00','YYYY-MM-DD HH:MI:SS')) from dual;

结果:13526973

将删除光阴转换为scn

select * from reportinfo

AS OF SCN 13526973

将reportinfo表中的scn点的数据掏出

然后可以根据这个数据进行还原操作

create table reporttest as select * from reportinfo where 1=0;

insert into reporttest select * from reportinfo AS OF SCN 13526973;

--上面两句应该可以合成一句

--create table reporttest as select * from reportinfo AS OF SCN 13526973;

这是reporttest表中便是scn点的reportinfo数据.处置惩罚即可

您可能还会对下面的文章感兴趣: