在Oracle 10g数据库中,引入了一个回收站(Recycle Bin)的数据库对象。
回收站,从原理上来说就是一个数据字典表,放置用户Drop掉的数据库对象信息。用户进行Drop操作的对象并没有被数据库删除,仍然会占用空间。除非是由于用户手工进行Purge或者因为存储空间不够而被数据库清掉。数据库有了这样的功能,能够减少很多不必要的麻烦。常常看到开发人员误把表删除,急急忙忙找DBA 来想办法的情况。相信随着10G的大范围应用,这种情形应该比较少见了,我们可以充分利用10g的闪回(FLASHBACK,闪回,回闪?)功能来避免大量的人工误操作。
DBA管理上的相关信息可以从USER_recyclebin(DBA_recyclebin)中获取。
为了便于测试,我们创建了一个表空间Foo,大小为1M,创建了一个用户Foo,默认的表空间为Foo.
SQL> CONNECT foo/foo;
Connected.
SQL> SELECT table_name FROM user_tables;
no rows selected
SQL>
SQL> DESC user_recyclebin
Name Null? Type
----------------------------------------- -------- -------------------
OBJECT_NAME NOT NULL VARCHAR2(30)
ORIGINAL_NAME VARCHAR2(32)
OPERATION VARCHAR2(9)
TYPE VARCHAR2(25)
TS_NAME VARCHAR2(30)
CREATETIME VARCHAR2(19)
DROPTIME VARCHAR2(19)
DROPSCN NUMBER
PARTITION_NAME VARCHAR2(32)
CAN_UNDROP VARCHAR2(3)
CAN_PURGE VARCHAR2(3)
RELATED NOT NULL NUMBER
BASE_OBJECT NOT NULL NUMBER
PURGE_OBJECT NOT NULL NUMBER
SPACE NUMBER
SQL>
user_recyclebin大多是自解释的,相对比较容易理解.
SQL> SELECT object_name FROM user_recyclebin;
no rows selected
SQL>
SQL> SELECT object_name FROM user_recyclebin;
no rows selected
SQL> CREATE TABLE foo AS SELECT * FROM DUAL;
Table created.
SQL> SELECT table_name FROM user_tables;
TABLE_NAME
----------------------------------------------
FOO
SQL> DROP TABLE foo;
Table dropped.
SQL> SELECT table_name FROM user_tables;
no rows selected
SQL> SHOW recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
FOO BIN$V3f/oYUITrCEF2cotS5JaA==$0 TABLE 2004-10-30:14:37:39
SQL>
SQL*Plus命令SHOW recyclebin等价于这条SQL:
SQL> SELECT original_name, object_name, TYPE, droptime FROM user_recyclebin;
ORIGINAL_NAME OBJECT_NAME TYPE DROPTIME
--------------- ------------------------------ ---------- --------------------
FOO BIN$V3f/oYUITrCEF2cotS5JaA==$0 TABLE 2004-10-30:14:37:39
SQL>
SQL> DESC "BIN$V3f/oYUITrCEF2cotS5JaA==$0"
Name Null? Type
----------------------------------------- -------- ----------------
DUMMY VARCHAR2(1)
SQL>
当一个表被删除并移动到"回收站"中,它的名字要进行一些转换。这样的目的显而易见是为了避免同类对象名称的重复。(这一点和Windows操作系统的回收站不同,Windows中的回收站经过了特殊的处理,操作系统文件可以重名。)
转换后的名字格式如下:
BIN$unique_id$version 其中BIN代表RecycleBin
unique_id是数据库中该对象的唯一标志,26个字符长度
version表示该对象的版本号
注:在10g beta 版本中,名字格式如下: RB$$objn$object_type$version
其中的RB,代表Recycle Bin. objn为表的目录对象号. object_type表示对象类型. version表示版本号. 由数据库指定。
下面我们验证一下回收站里数据库对象名字的唯一性:
SQL> CREATE TABLE foo AS SELECT * FROM DUAL;
Table created.
SQL> SELECT table_name FROM user_tables;
TABLE_NAME
------------------------------------------------------------
FOO
SQL> DROP TABLE foo;
Table dropped.
SQL> SHOW recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
FOO BIN$VL+ZsqVlQF6R2nYnwAqtvw==$0 TABLE 2004-10-30:15:01:42
FOO BIN$V3f/oYUITrCEF2cotS5JaA==$0 TABLE 2004-10-30:14:37:39
SQL>
能看出来,虽然源表名字相同,在回收站里的对象名字是不同的。
针对Recycle Bin对象的操作
已经放到回收站里的表是不能用drop 命令删除的(注意对象名字上的双引号):
SQL> DROP table "BIN$V3f/oYUITrCEF2cotS5JaA==$0"
2 /
DROP table "BIN$V3f/oYUITrCEF2cotS5JaA==$0"
*
ERROR at line 1:
ORA-38301: can not perform DDL/DML over objects in Recycle Bin
SQL>
如果要清掉该对象,使用purge命令:
SQL> PURGE table "BIN$V3f/oYUITrCEF2cotS5JaA==$0"
2 /
Table purged.
SQL> SELECT object_name, original_name FROM user_recyclebin;
OBJECT_NAME ORIGINAL_NAME
------------------------------ ---------------
BIN$VL+ZsqVlQF6R2nYnwAqtvw==$0 FOO
SQL>
对象已经清掉。如果直接清空所有的Recycle Bin中的对象:
SQL> PURGE RECYCLEBIN;
Recyclebin purged.
SQL> SELECT object_name, original_name FROM user_recyclebin;
no rows selected
SQL>
恢复表,用回闪表的功能:
SQL> FLASHBACK TABLE foo TO BEFORE DROP;
Flashback complete.
SQL>SELECT table_name FROM user_tables;
TABLE_NAME
------------------------------------------------------------
FOO
SQL>
注:在10g Beta版本中,使用Undrop命令来做到这一点.
有的时候,可能同一个名字的表被删除到回收站中:
SQL> DROP TABLE FOO;
Table dropped.
SQL> SHOW RECYCLEBIN
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
FOO BIN$lfTbzOjISXaw8u0BIO7pNA==$0 TABLE 2004-10-30:15:18:03
SQL> CREATE TABLE foo AS SELECT * FROM DUAL;
Table created.
SQL> DROP TABLE foo;
Table dropped.
SQL> SHOW RECYCLEBIN
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
FOO BIN$J63QaUaKTmC1glat+imjeg==$0 TABLE 2004-10-30:15:18:50
FOO BIN$lfTbzOjISXaw8u0BIO7pNA==$0 TABLE 2004-10-30:15:18:03
SQL> FLASHBACK TABLE FOO TO BEFORE DROP;
Flashback complete.
SQL> SHOW RECYCLEBIN
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
FOO BIN$lfTbzOjISXaw8u0BIO7pNA==$0 TABLE 2004-10-30:15:18:03
SQL>
默认的恢复是第一个被删除的FOO表。如果要恢复指定的表,可以在FLASHBACK TABLE 后面加上指定的RECYCLEBIN 参数指定其他的名字:
SQL> FLASHBACK TABLE "BIN$lfTbzOjISXaw8u0BIO7pNA==$0" TO BEFORE DROP;
FLASHBACK TABLE "BIN$lfTbzOjISXaw8u0BIO7pNA==$0" TO BEFORE DROP
*
ERROR at line 1:
ORA-38312: original name is used by an existing object
SQL> FLASHBACK TABLE "BIN$lfTbzOjISXaw8u0BIO7pNA==$0" TO BEFORE DROP
2 RENAME TO foo2;
Flashback complete.
SQL>
分享到:
相关推荐
对于oracle10g的Recycle Bin回收站描述
在Oracle10g中,引入了一个回收站(Recycle Bin)的概念。回收站,从原理上来说就是一个数据字典表,放置用户Drop掉的数据库对象信息。被用户Drop的对象并没有被Oracle删除,仍然会占用空间。除非是用户手工进行Purge...
Windows中回收站(Recycle Bin)的存取方法.源码,经测试,很好用,vc的,欢迎下载
商业编程-源码-Windows中回收站(Recycle Bin)的存取方法.zip
Oracle10g新特性:Recycle Bin回收站
我想用CFile::Remove(或其它可行的方法)删除一个文件,但是只是想将它送到Recycle Bin里面,而不是永久性地删除它,这样我的用户就可以在必要的时候能恢复这个文件...关键字:回收站,Recycle Bin,Shell API,外壳编程
在Oracle 10g数据库中,引入了一个回收站(Recycle Bin)的数据库对象。 回收站,顾名思义,它就是存储被删掉的东西。从原理上来说就是一个数据字典表,放置用户删除(drop)掉的数据库对象信息。用户进行删除操作的...
演示了访问系统回收站的函数接口,包括清空回收站以及恢复回收站中的文件。
Unraid服务器的VFS回收站该插件为samba共享实现了一个回收站。 此插件仅适用于V6.4和更高版本的Unraid。
将以上所有代码全部拷贝放入一个文件然后给与执行权限,执行后全局回收站就建好了,rm --help查看rm的用法,recycle --help查看recycle命令的用法。 以上代码放一个脚本文件后赋予可执行权限,执行此脚本,然后退出...
Auto Recycle Bin是一款可以帮助用户自动清理回收站文件的小工具,一般来说,我在删除无用文件时都是直接移除到回收站而不是选择永久性删除,毕竟提防自己真的误删除了,但久而久之,回收站就占用了好多好多的空间,...
如要设置“回收站”的属性,请按下列步骤操作:双击桌面上的“回收站”快捷方式,在“回收站”文件夹的左上角,右键单击“回收站”图标,然后单击“属性”。 组策略法 1.运行组策略,方法是:单击“开始”\运行...
recycle.bin是什么-.docx
手机回收小程序 amouse_mobile_recycle 4.0.6.zip微信小程序模板源码
回收站将文件和文件夹移到Windows回收站安装二进制...用法 $ recycle-bin --helpUsage: recycle-bin <path> [...]建造安装并运行: $ build有关的清空Windows回收站-将文件和文件夹移至垃圾箱-跨平台-清空垃圾-跨平台
撤消关闭标签 记录关闭的标签页 特性: 1. 自动记录关闭的标签页,按照关闭时间排序。 2. 显示标签当前/总页数,每页12条记录,提供上下页按钮。 ... 4. 可以清空所有标签页。...5. 可以在说有的chrome窗口共享标签页。...
ListView列表中使用 Recycle
The presentation of the Recycle Bin is similar with dustbin. HE3—Good Feature The Recycle Bin collects files the user deleted and can recover them. HE4—Good Feature The user can choose whether ...
回收站使您可以检索可能已在Tally记帐软件中意外删除的记录。 它是由Shweta Softwares开发的免费工具-https://www.rtslink.com。它类似于Windows Recycle-bin,可让您恢复已删除的文件。