oracle10g recyclebin 详解

oracle10g 提供了类似操作系统中的回收站功能。当drop table的时候,实际上只是将其重命名,并将table以及相关联的对象如index,constraint等放到回收站(RecycleBin)中,后续如果发现drop错了table,可以使用flashback table命名将回收站中的table还原,这就是oracle10g的Flashback Drop功能。
    1.什么是Recycle Bin
    实际上,Recycle Bin只是一个保存被drop的对象的一个数据字典表。所以,可以通过如下语句查询回收站中的信息:select * from recyclebin
    除非拥有sysdba权限,每个用户只能看到属于自己的对象。所以,对于用户来说,好像每个人都拥有自己的回收站。即使用户有删除其他schema对象的权限,也只能在recyclebin中看到属于自己的对象。
SQL> conn hr/hr
已连接。
SQL> drop table test;
表已删除。
SQL> conn test/test
已连接。
SQL> drop table test;
表已删除。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ --------------------------------
BIN$a5ZBzpZWTQ2TNYt7SOzUFQ==$0 TEST
SQL> conn hr/hr
已连接。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ --------------------------------
BIN$HX/8VbJARoea6Eckpactvg==$0 TEST

注意:两个对象名是不一样的。
以下几种drop不会将相关对象放进RecycleBin:
* drop tablespace:会将RecycleBin中所有属于该tablespace的对象清除
* drop user:会将RecycleBin中所有属于该用户的对象清除
* drop cluster:会将RecycleBin中所有属于该cluster的成员对象清除
* drop type:会将RecycleBin中所有依赖该type的对象清除
    RecycleBin中的对象会被系统自动按照规则重命名,这是为了防止命名冲突。命名格式为:BIN$unique_id$version
    其中unique_id是26个字符的对象唯一标识符,version则是对象在数据库中的版本号。

SQL> conn test/test
已连接。
SQL> create table t(id int);
表已创建。
SQL> drop table t;
表已删除。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ -------------------------------
BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 T
BIN$a5ZBzpZWTQ2TNYt7SOzUFQ==$0 TEST

SQL> create table t(id int);
表已创建。
SQL> drop table t;
表已删除。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ -------------------------------
BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 T
BIN$a5ZBzpZWTQ2TNYt7SOzUFQ==$0 TEST
BIN$to91fMaiSSCcj2eI36eDyQ==$0 T
   可以看到,删除table t后,重建一个名为t的table,再次删除,其unique_id是不一样的。
  
   这时,做一个还原看看:

SQL> flashback table t to before drop rename to t;
闪回完成。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ -------------------------------
BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 T

这里,Oracle选择了最后一次删除的T表还原。

再次删除
SQL> drop table t;
表已删除。
SQL> select object_name,original_name from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ --------------------------------
BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 T
BIN$aafxCq9gTbGMvrqnLMP69A==$0 T
    可以看到unique_id又变了。所以,通过这种命名方式,避免了对于删除table后又重建了同名table的情况可能造成的命名冲突。

2.如何启用/禁用RecycleBin

可以通过参数禁用或启用recyclebin这个特性
在Oracle 10gR1中,通过修改一个隐含_recyclebin为False可以禁
用这个特性,

在Oracle 10gR2中,recyclebin变成了一个常规参数,可以在session/system级动态修改 :
SQL> show parameter recyclebin
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------
recyclebin                           string      on
SQL> alter session set recyclebin=off;
会话已更改。
SQL> alter session set recyclebin=on;
会话已更改。
SQL> alter system set recyclebin=off;
系统已更改。
SQL> alter system set recyclebin=on;
系统已更改。

3.如何查看RecycleBin中的信息
    前面已经提到,用户可以通过查询recyclebin来查看属于自己的被drop的对象。

SQL> select object_name,object_type from dba_objects where object_name='RECYCLEBIN';

OBJECT_NAME
--------------------------------------------------------------------------------
OBJECT_TYPE
-------------------
RECYCLEBIN
SYNONYM


SQL> select owner,synonym_name,table_owner,table_name from dba_synonyms where synonym_name='RECYCLEBIN';

OWNER                          SYNONYM_NAME
------------------------------ ------------------------------
TABLE_OWNER                    TABLE_NAME
------------------------------ ------------------------------
PUBLIC                         RECYCLEBIN
SYS                            USER_RECYCLEBIN

可以发现,实际上recyclebin是user_recyclebin的一个公共同义词。还可以通过dba_recyclebin查看系统中所有被drop的对象,但这里没有all_recyclebin视图。
另外,Sqlplus也提供了一个专门的命令
SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
T                BIN$aafxCq9gTbGMvrqnLMP69A==$0 TABLE        2008-09-27:16:02:03
T                BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 TABLE        2008-09-27:15:48:13

    但该命令只能看到被drop的table,该table对应的index等只能通过查询获取。
SQL> create table t(id int);
表已创建。
SQL> create index ix_t on t(id);
索引已创建。
SQL> alter table t add constraint con_t_pk primary key(id) using index ix_t;
表已更改。
SQL> drop table t;
表已删除。
SQL> show recyclebin;
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
T                BIN$Lw6h3tI8SjirrzY38PbKZA==$0 TABLE        2008-09-27:16:41:51
T                BIN$aafxCq9gTbGMvrqnLMP69A==$0 TABLE        2008-09-27:16:02:03
T                BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 TABLE        2008-09-27:15:48:13

4.如何清除RecycleBin中的对象
    回收站中的东西多了,自然要清除。Oracle10g增加了一个新的关键字purge来执行清除recyclebin的功能。
    purge table table_name可以清除指定的table,这里的table_name既可以是table原来的名字,也可以是回收站中按规则自动命名的名字。
SQL> show recyclebin;
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
T                BIN$Lw6h3tI8SjirrzY38PbKZA==$0 TABLE        2008-09-27:16:41:51
T                BIN$aafxCq9gTbGMvrqnLMP69A==$0 TABLE        2008-09-27:16:02:03
T                BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 TABLE        2008-09-27:15:48:13

1)SQL> purge table test;
    表已清除。
2)SQL> purge table "BIN$Lw6h3tI8SjirrzY38PbKZA==$0";
表已清除。
SQL> show recyclebin;
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
T                BIN$aafxCq9gTbGMvrqnLMP69A==$0 TABLE        2008-09-27:16:02:03
T                BIN$2YtUFN8ZTIqKDKXAPE7HgQ==$0 TABLE        2008-09-27:15:48:13
3) SQL> purge tablespace users;
表空间已清除。
4) SQL> purge tablespace users user hr;
表空间已清除。
Purge recyclebin可以清除执行该命令的用户所能看到的所有recyclebin对象。也就是普通用户能清除属于自己的对象,而sysdba用户则能清除所有recyclebin中的对象。
5)purge index可以清除index对象。
SQL> create table t1(id int);
表已创建。
SQL> create index ix_t1 on t1(id);
索引已创建。
SQL> drop table t1;
表已删除。
SQL> select object_name,original_name,type from recyclebin;
OBJECT_NAME                    ORIGINAL_NAME
------------------------------ --------------------------------
TYPE
-------------------------
BIN$lTA1iH/bTzqqe4/qmpBeJw==$0 T
TABLE

BIN$6G08DJvESIyFDrYA9nO24Q==$0 IX_T1
INDEX

BIN$El5FGgr8RF6MY6HiHlnoRw==$0 T1
TABLE
SQL> purge index ix_t1;

索引已清除。

SQL> select object_name,original_name,type from recyclebin;

OBJECT_NAME                    ORIGINAL_NAME
------------------------------ --------------------------------
TYPE
-------------------------
BIN$lTA1iH/bTzqqe4/qmpBeJw==$0 T
TABLE

BIN$El5FGgr8RF6MY6HiHlnoRw==$0 T1
TABLE
SQL>
5.如何还原RecycleBin中的对象
    前面的试验中已经使用Flashback table来还原过被删除的table.
SQL> show recyclebin
ORIGINAL NAME    RECYCLEBIN NAME                OBJECT TYPE  DROP TIME
---------------- ------------------------------ ------------ -------------------
T                BIN$lTA1iH/bTzqqe4/qmpBeJw==$0 TABLE        2008-09-27:17:02:16
T1               BIN$El5FGgr8RF6MY6HiHlnoRw==$0 TABLE        2008-09-27:17:03:25
SQL> flashback table t to before drop rename to t;

闪回完成。

SQL>
 SQL> desc test名称 是否为空? 类型
----------------------------------------- -------- ----------------------------

    ID NUMBER(38)
    如果多次删除同名的table,则使用上面的语句还原的是最后一个被删除的test表,这里也可以使用RecycleBin给table的名字来做还原。
SQL> flashback table "BIN$GoZUqZ6GS222JZdcCtFlHQ==$0" to before drop rename to test
    闪回完成。

你可能感兴趣的:(oracle,sql)