ORACLE回收站机制介绍

回收站概念

从ORACLE
10g开始,引入了一个叫回收站(Recycle Bin)的概念。它的全称叫Tablespace Recycle
Bin。回收站实际是一个逻辑容器(逻辑区域),原理有点类似于WINDOW系统的回收站。它以表空间中现有已经分配的空间为基础,而不是从表空间上物理
划出一个固定区域用作回收站。这意味着回收站和表空间中的对象共用存储区域、系统没有给回收站预留空间。因此,当表被DROP后,如果可用空间充足,并且
没有对回收站进行清理,那么被DROP掉的对象会一直存在回收站中,但是如果可用空间紧张的情况下,数据库会根据先进先出的顺序覆盖Recycle
Bin中的对象。所以回收站机制也不是百分百的保险机制。另外从原理上来说它就是一个数据字典表,放置用户Drop掉的数据库对象信息。用户进行Drop
操作的对象并没有真正被数据库删除,仍然会占用空间。除非是由于用户手工进行Purge或者因为存储空间不够而被数据库清掉。数据库有了这样的功能,能够
减少很多不必要的麻烦。当用户、开发人员、甚至DBA误操作删除了表,那么我们不必还原整个数据库或表空间,直接使用ORACLE
10g的闪回(FLASHBACK,闪回)功能来还原被删除的表。这样我们就能避免大量的人工误操作。这是一个对DBA相当有用的功能。

 

回收站功能


收站这个特性主要的好处就是在误删除一个表时有一个恢复机制,不必通过数据库还原来实现。避免大量的人工误操作。以及数据库还原等复杂的操作。让数据库的
管理、维护更加简单、方便。如果是SQL SERVER数据库,就必须还原整个数据库来找到被DROP掉的表。可见回收站功能确实是一个开创性的功能。

 

管理回收站

开启、关闭回收站

首先你可以通过命令查看数据库是否开启了回收站机制, 如下所示 VALUE= ON表示开启了回收站机制。OFF则表示回收站机制关闭。

SQL> SHOW PARAMETER RECYCLEBIN;
 
NAME              TYPE        VALUE
--------     ----------- ----------
recyclebin      string         ON
 
 
SQL> SELECT NAME, VALUE FROM V$PARAMETER WHERE NAME='recyclebin';
 
NAME                      VALUE
----------------- --------------------
recyclebin                  on

可以通过设置初始化参数recyclebin启用或禁用回收站功能。当然也可以用命令关闭回收站

SQL> ALTER SYSTEM SET RECYCLEBIN=OFF;
 
System altered.
 
SQL> ALTER SESSION SET RECYCLEBIN=OFF;
 
Session altered.
 
SQL> SHOW PARAMETER RECYCLEBIN;
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
recyclebin                           string      OFF

可以用命令开启回收站

SQL> ALTER SYSTEM SET RECYCLEBIN=ON;
 
System altered.
 
SQL> ALTER SESSION SET RECYCLEBIN =ON;
 
Session altered.
 
SQL> SHOW PARAMETER RECYCLEBIN;
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
recyclebin                           string      ON

 

查看回收站对象

我们先来看看一个例子,如下所示,假如不小心误操作DROP了表test,那么我们如何在回收站查看被DROP的表对象呢?

SQL> show user
USER is "ODS"
 
SQL> create table test(name varchar2(16));
 
Table created.
 
SQL> insert into test select 'kerry' from dual;
 
1 row created.
 
SQL> insert into test select 'ken' from dual;
 
1 row created.
 
SQL> commit;
 
Commit complete.
 
SQL> drop table test;
 
Table dropped.

SQL 1:

SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vltN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:11:25:38

SQL 2: 其中RECYCLEBIN是USER_RECYCLEBIN 的同义词。

COL OBJECT_NAME FOR A30
COL ORIGINAL_NAME FOR A8
COL OPERATION FOR A9
COL TYPE FOR A8
COL DROPTIME FOR A19
COL TS_NAME FOR A30
SELECT OBJECT_NAME 
          ,ORIGINAL_NAME
          ,OPERATION
          ,TYPE
          ,DROPTIME
          ,TS_NAME
FROM RECYCLEBIN;
 
 
--查看数据库当前用户的回收站对象
 
SQL> SELECT * FROM RECYCLEBIN

SQL 3:

--查看数据库当前用户的回收站对象

SQL> SELECT * FROM USER_RECYCLEBIN;

SQL 4: 需要相关权限才能查询。

--查看数据库回收站所有对象

SQL> SELECT * FROM DBA_RECYCLEBIN;

为了避免被删除的表与同类对象名称的重复,被删除的表以及相依的对象放到回收站后,ORACLE数据库会对被删除的对象名称进行重命名,例如表TEST表

SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vltN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:11:25:38

我们又创建了表TEST,然后删除了该表TEST,如下所示,虽然ORIGINAL_NAME一致,但是RECYCLEBIN NAME则有所不同。

SQL> create table test(name varchar2(16));
 
Table created.
 
SQL> drop table test;
 
Table dropped.
 
SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vluN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:14:40:52
TEST             BIN$BLmi9vltN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:11:25:38

RECYCLEBIN NAME的命名规则为BIN$GUID$Version 其中GUID为GlobalUID,是一个全局唯一、24个字符长的标识对象,它是ORACLE内部使用的标识。 其中$version是ORACLE数据库分配的版本号。

 

还原回收站对象

还原回收站被删除的表、索引等对象, 是通过Flashback Drop实现的。如下所示。

SQL> FLASHBACK TABLE TEST TO BEFORE DROP;
 
Flashback complete.
 
 
SQL> SELECT * FROM TEST;
 
NAME
----------------
kerry
ken

但是如果出现上面两个TEST表都被删除时,此时的Flashback Drop就有点意思了

SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vlxN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:15:10:25
TEST             BIN$BLmi9vlwN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:15:10:09
SQL> flashback table test to before drop;
 
Flashback complete.
 
SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vlwN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:15:10:09
 
SQL> select * from test;
 
no rows selected

如上所示,如果两个相同名字的表TEST被删除了,此时闪回被DROP的表TEST,实质是闪回最后一个被删除的表(后进先出原则),如果此时继续闪回操作就会报ORA-38312错误

 
SQL> flashback table test to before drop;
flashback table test to before drop
*
ERROR at line 1:
ORA-38312: original name is used by an existing object

此时可以在闪回过程中对表名进行重命名解决问题。。

SQL> flashback table test to before drop rename to test_2;
 
Flashback complete.
 
SQL> select * from test_2;
 
NAME
----------------
kerry
ken

另外,如果回收站有两个被DROP掉的表TEST, 如果想闪回第一个被删除的表,那该怎么办呢?

SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST             BIN$BLmi9vlxN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:15:10:25
TEST             BIN$BLmi9vlwN3TgUKjAgYxoiA==$0 TABLE        2014-10-06:15:10:09

其实这个也很好处理,直接指定RECYCLEBIN NAME进行闪回即可。

SQL> flashback table "BIN$BLmi9vlwN3TgUKjAgYxoiA==$0" to before drop;

 

清空回收站

数据库对象删除后,数据库会把它重命名为BIN$开头的对象,你可以通
过ORIGINAL_NAME查看它对应的原始对象名称。记住,将表放在回收站里并不在原始表空间中释放空间。如果您希望完全删除该表,而不让该表放入回
收站,可以使用以下命令永久删除该表。当然这样操作后,你也不能通过使用闪回特性闪回该表了。

DROP TABLE TABLE_NAME PURGE;

如果数据库中删除表时都放入回收站,因而没有释放所占空间,那么当空闲的空间不足时,已经删除的表是否还会侵占存储空间呢?

答案很简单:当表空间被回收站数据完全占满,以至于必须扩展数据文件来容纳更多数据时,可以说表空间处于“空间压力”情况下。此时,对象以先进先出的方式从回收站中自动清除。在删除表之前,相关对象(如索引)被删除。

同样,空间压力可能由特定表空间定义的用户限额而引起。表空间可能有足够的空余空间,但用户可能将其在该表空间中所分配的部分用完了。在这种情况下,Oracle 自动清除该表空间中属于该用户的对象。

此外,有几种方法可以手动控制回收站。如果在删除名为 TEST 的特定表之后需要从回收站中清除它,可以执行

PURGE TABLE TABLE_NAME;

或者使用其回收站中的名称:

PURGE TABLE "BIN$04LhcpndanfgMAAAAAANPw==$0";

此命令将从回收站中删除表 TEST 及所有相关对象,如索引、约束等,从而节省了空间。但是,如果要从回收站中永久删除索引,则可以使用以下命令来完成工作:

PURGE INDEX IN_TEST1_O1;

此命令将仅仅删除索引,而将表的拷贝留在回收站中。有时在更高级别上进行清除可能会有用。例如,您可能希望清除表空间 USERS 的回收站中的所有对象。可以执行:

PURGE TABLESPACE USERS;

您也许希望只为该表空间中特定用户清空回收站。在数据仓库类型的环境中,用户创建和删除许多临时表,此时这种方法可能会有用。您可以更改上述命令,限定只清除特定的用户:

PURGE TABLESPACE USERS USER SCOTT;

要释放整个回收站占用的空间,您需要使用以下命令清空回收站:

PURGE RECYCLEBIN;

记住PURGE RECYCLEBIN只是清除当前用户回收站中的对象,DBA_RECYCLEBIN下的的对象并没有删除,如果你要清除当前数据库回收站的对象,必须使用下面命令(DBA权限)

PURGE DBA_RECYCLEBIN

 

Flashback Drop注意事项

1:只能用于非系统表空间和本地管理的表空间。

如下所示,在系统表空间中,表对象删除后就真的从系统中删除了,而不是存放在回收站中。

SQL> show user
USER is "SYS"
SQL> create table test(name varchar2(12));
 
Table created.
 
SQL> drop table test;
 
Table dropped.
 
SQL> show recyclebin;

2:对象的参考约束不会被恢复,指向该对象的外键约束需要重建。

3:对象能否恢复成功,取决于对象空间是否被覆盖重用。

4:当删除表时,依赖于该表的物化视图也会同时删除,但是由于物化视图并不会放入recycle binzhong,因此当你执行flashback drop时,

并不能恢复依赖其的物化视图。需要DBA手工重建。

5:对于回收站(Recycle Bin)中的对象,只支持查询。不支持任何其他DML、DDL等操作。  

时间: 2024-09-14 10:59:00

ORACLE回收站机制介绍的相关文章

Oracle回收站及flashback drop(上)

Oracle回收站及flashback drop(上)   一.1  BLOG文档结构图 Oracle回收站及flashback drop - 3 - 1.1 BLOG文档结构图 - 3 - 1.2 前言部分 - 3 - 1.2.1 导读和注意事项 - 3 - 1.2.2 相关参考文章链接 - 4 - 1.2.3 本文简介 - 4 - 1.3 相关知识点扫盲(摘自网络+个人总结) - 5 - 1.3.1 闪回 - 5 - 1.3.2 闪回技术分类 - 6 - 1.3.3 闪回删除(Flashba

Oracle回收站及flashback drop(下)

Oracle回收站及flashback drop(下) 本文接着上篇文章继续讲解:http://blog.itpub.net/26736162/viewspace-2121136/ 第二章 实验部分 二.1  实验环境介绍 项目 primary db db 类型 单实例 db version 11.2.0.2.0 db 存储 ASM     二.2  实验目标 本次我们模拟2个实验: 1.系统表空间的对象不能闪回 2.在版本为11.2.0.3及以下的情况下,当回收站对象过多时查询表空间大小时涉及

Oracle压缩功能介绍

大家听到这个词,一定就想到了节省硬盘空间吧.没错,它就是用来干这个的,但是向外延伸一下,它不仅可以节省硬盘空间,更可以节省带宽以及内存的使用(cpu有一点点损耗因为需要更多的计算取值操作,但是鉴于大多数环境下cpu都有空闲,所以也可以忽略了). Basiccompression这个功能从9i开始就有提供,11gr1开始提供了新的压缩功能,即OLTP compression.Basic compression是包括在EE版本中的,不需要额外收费,但是OLTP compression则需要额外的Or

验证码对抗之路及现有验证机制介绍

验证码对抗之路及现有验证机制介绍 目明@阿里聚安全 yahoo邮箱在九几年的时候,业务深受各种邮箱机器人的困扰,存在着大量的垃圾邮件,于是他们找到了当时仍在读大学的路易斯·冯·安(Luis von Ahn),并设计了经典的图形验证码,即通过简单的扭曲图形文字进行机器的识别. 通过这个简单的图形,他们很快的控制住了垃圾邮件的数量,并将大量的机器人据之门外. 但是即使验证码解决了垃圾邮件的问题,我们仍要提出一个问句: 验证码是必要的吗? 阿里有句简单的话:不忘初心,方得始终. 验证码不是一个功能性的

5.创建表,使用alter进行表信息的增删改,Oracle回收站,集合运算

 1  Oracle基于用户的管理方案 2 DDL语句可以管理数据库的对象有:视图   索引  序列  同义词   约束 3  创建一个表,有2个条件(1 有权限:2有表空间)    Oracle给你提供了默认的resource. 4 创建表,表信息的增删改,Oracle回收站 DDL          管理数据库的对象                    表                    视图 索引 序列 同义词 约束(..... )            oracle基于用户的

深入剖析 - Oracle SCN机制详细解读

SCN介绍 SCN即系统改变号(System Change Number),是在某个时间点定义数据库已提交版本的时间戳标记. Oracle为每个已提交的事务分配一个唯一的SCN. SCN的值是对数据库进行更改的逻辑时间点. Oracle使用此编号记录对数据库所做的更改.在数据库中,SCN也可以说是无处不在,数据文件头,控制文件,数据块头,日志文件等等都标记着SCN.也正是这样,数据库的一致性维护和SCN密切相关.不管是数据的备份,恢复都是离不开SCN的. SCN是一个6字节(48bit)的数字,

oracle锁机制的延续——并发与多版本1

开发多用户数据库应用,最大的难题之一是:一方面要力争最大的并发访问,而同时还要确保每一用户 能以一致的方式读取和修改数据.力争最大的并发访问需要用锁定机制,而确保一致读和修改数据则需要一些并发控制机制.    1.并发控制:     并发控制(concurrency control)是数据库提供的函数集合,允许多个人同时访问和修改数据.锁(lock)是Oracle管理共享数据库资源并发访问并防止并发数据库事务之间"相互干涉"的核心机制之一.总结一下,Oracle使用了多种锁,包括:  

oracle 存储过程详细介绍(创建,删除存储过程,参数传递等)_oracle

oracle 创建,删除存储过程,参数传递,创建,删除存储函数,存储过程和函数的查看,包,系统包 认识存储过程和函数 存储过程和函数也是一种PL/SQL块,是存入数据库的PL/SQL块.但存储过程和函数不同于已经介绍过的PL/SQL程序,我们通常把PL/SQL程序称为无名块,而存储过程和函数是以命名的方式存储于数据库中的.和PL/SQL程序相比,存储过程有很多优点,具体归纳如下: * 存储过程和函数以命名的数据库对象形式存储于数据库当中.存储在数据库中的优点是很明显的,因为代码不保存在本地,用户

Oracle 10g lite 介绍

原文整理自网络: 摘要:近年来,嵌入式数据库发展迅速,出现了许多优秀的软件产品,这些产品可以广泛应用于资源紧张的嵌入式计算机或手持终端.Oracle作为著名数据库厂商也推出了自己的嵌入式数据库产品.本文着重介绍了ORACLE10G LITE嵌入式数据库系统的特点.机制以及如何应用于某机动式指挥系统. 中国论文网 关键词:嵌入式数据库:手持终端:Oracle 10g lite 中图分类号:TN915.09 文献标识码:A文章编号:1007-9599 (2012) 08-0000-02 一. 嵌入式