Oracle10G以前执行drop table后表就即被删除了。10G后引入了垃圾回收站的概念recyclebin。如果仍只是drop table xxx,表不会立即被删除,而是被暂时放入回收站。 可以保障某些误操作后还可以将表还原。 1.查看数据库是否开户recyclebin功能 SQL> show parameter recyclebin; NAME TYPE VALUE recyclebin string on 或者只将当前会话开启功能 alter session set recyclebin = on; 2.查看当前用户中的垃圾回收站的对象: select * from recyclebin; 3.drop table xxx时,不希望将表放入垃圾回收站,而是直接drop drop table xxx purge; 4.将recyclebin中对象还原或清除 --还原 flashback table "xxxxx" to before drop "xxxx"乃是recyclebin视图中OBJECT_NAME字段名称 flashback table "xxxxx" to before drop 亦可换成 flashback table "xxxxx" to before drop rename to xxxx重命名 --清除 purge table xxxx purge 还可以指定某个表空间和某个用户下表。 ps: recycelbin中还保留了index。 如个表空间不够创建新对象时,oracle将自动请除recyclebin中的对象。 以下几种drop不会将相关对象放进RecycleBin: * drop tablespace:会将RecycleBin中所有属于该tablespace的对象清除 * drop user:会将RecycleBin中所有属于该用户的对象清除 * drop cluster:会将RecycleBin中所有属于该cluster的成员对象清除 * drop type:会将RecycleBin中所有依赖该type的对象清除
惭愧啊、早起刷分果断不是好事 hr@ORCL> drop table t;Table dropped.hr@ORCL> show recyclebin ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME ---------------- ------------------------------ ------------ ------------------- T BIN$zgWo4TsLBg/gQAB/AQAWJg==$0 TABLE 2012-11-09:09:13:30 hr@ORCL> rename "BIN$zgWo4TsLBg/gQAB/AQAWJg==$0" to tttt;Table renamed.hr@ORCL> show recyclebin ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME ---------------- ------------------------------ ------------ ------------------- T TTTT TABLE 2012-11-09:09:13:30
1.查看数据库是否开户recyclebin功能 SQL> show parameter recyclebin; NAME TYPE VALUE recyclebin string on
或者只将当前会话开启功能
alter session set recyclebin = on; 2.查看当前用户中的垃圾回收站的对象:
select * from recyclebin;
3.drop table xxx时,不希望将表放入垃圾回收站,而是直接drop drop table xxx purge;
4.将recyclebin中对象还原或清除
--还原
flashback table "xxxxx" to before drop "xxxx"乃是recyclebin视图中OBJECT_NAME字段名称 flashback table "xxxxx" to before drop 亦可换成 flashback table "xxxxx" to before drop rename to xxxx重命名
--清除
purge table xxxx purge 还可以指定某个表空间和某个用户下表。 ps: recycelbin中还保留了index。 如个表空间不够创建新对象时,oracle将自动请除recyclebin中的对象。
以下几种drop不会将相关对象放进RecycleBin:
* drop tablespace:会将RecycleBin中所有属于该tablespace的对象清除
* drop user:会将RecycleBin中所有属于该用户的对象清除
* drop cluster:会将RecycleBin中所有属于该cluster的成员对象清除
* drop type:会将RecycleBin中所有依赖该type的对象清除
无非就是从oracle10g开始,增加了一个逻辑删除功能呗当recyclebin 打开的时候,逻辑删除,同时修改表名
oracle正常读取的是非逻辑删除的表这个跟windows的回收站木有太大的区别。
● 该表空间又要创建新的对象,需要分配空间
在这种情形下就会造成recyclebin的空间压力,这是触发recyclebin主动删除对象的唯一原因
rename 木有问题,你用的神马版本?
hr@ORCL> drop table t;Table dropped.hr@ORCL> show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
T BIN$zgWo4TsLBg/gQAB/AQAWJg==$0 TABLE 2012-11-09:09:13:30
hr@ORCL> rename "BIN$zgWo4TsLBg/gQAB/AQAWJg==$0" to tttt;Table renamed.hr@ORCL> show recyclebin
ORIGINAL NAME RECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
T TTTT TABLE 2012-11-09:09:13:30