ORACLE回收站机制介绍
2015-05-13 15:12
260 查看
回收站概念
从ORACLE10g开始,引入了一个叫回收站(RecycleBin)的概念。它的全称叫TablespaceRecycleBin。回收站实际是一个逻辑容器(逻辑区域),原理有点类似于WINDOW系统的回收站。它以表空间中现有已经分配的空间为基础,而不是从表空间上物理划出一个固定区域用作回收站。这意味着回收站和表空间中的对象共用存储区域、系统没有给回收站预留空间。因此,当表被DROP后,如果可用空间充足,并且没有对回收站进行清理,那么被DROP掉的对象会一直存在回收站中,但是如果可用空间紧张的情况下,数据库会根据先进先出的顺序覆盖Recycle
Bin中的对象。所以回收站机制也不是百分百的保险机制。另外从原理上来说它就是一个数据字典表,放置用户Drop掉的数据库对象信息。用户进行Drop操作的对象并没有真正被数据库删除,仍然会占用空间。除非是由于用户手工进行Purge或者因为存储空间不够而被数据库清掉。数据库有了这样的功能,能够减少很多不必要的麻烦。当用户、开发人员、甚至DBA误操作删除了表,那么我们不必还原整个数据库或表空间,直接使用ORACLE10g的闪回(FLASHBACK,闪回)功能来还原被删除的表。这样我们就能避免大量的人工误操作。这是一个对DBA相当有用的功能。
回收站功能
回收站这个特性主要的好处就是在误删除一个表时有一个恢复机制,不必通过数据库还原来实现。避免大量的人工误操作。以及数据库还原等复杂的操作。让数据库的管理、维护更加简单、方便。如果是SQLSERVER数据库,就必须还原整个数据库来找到被DROP掉的表。可见回收站功能确实是一个开创性的功能。
管理回收站
开启、关闭回收站
首先你可以通过命令查看数据库是否开启了回收站机制,如下所示VALUE=ON表示开启了回收站机制。OFF则表示回收站机制关闭。
可以通过设置初始化参数recyclebin启用或禁用回收站功能。当然也可以用命令关闭回收站
可以用命令开启回收站
查看回收站对象
我们先来看看一个例子,如下所示,假如不小心误操作DROP了表test,那么我们如何在回收站查看被DROP的表对象呢?
SQL1:
SQL2: 其中RECYCLEBIN是USER_RECYCLEBIN的同义词。
SQL3:
--查看数据库当前用户的回收站对象
SQL>SELECT*FROMUSER_RECYCLEBIN;
SQL4: 需要相关权限才能查询。
--查看数据库回收站所有对象
SQL>SELECT*FROMDBA_RECYCLEBIN;
为了避免被删除的表与同类对象名称的重复,被删除的表以及相依的对象放到回收站后,ORACLE数据库会对被删除的对象名称进行重命名,例如表TEST表
我们又创建了表TEST,然后删除了该表TEST,如下所示,虽然ORIGINAL_NAME一致,但是RECYCLEBINNAME则有所不同。
RECYCLEBINNAME的命名规则为BIN$GUID$Version其中GUID为GlobalUID,是一个全局唯一、24个字符长的标识对象,它是ORACLE内部使用的标识。其中$version是ORACLE数据库分配的版本号。
还原回收站对象
还原回收站被删除的表、索引等对象,是通过FlashbackDrop实现的。如下所示。
但是如果出现上面两个TEST表都被删除时,此时的FlashbackDrop就有点意思了
如上所示,如果两个相同名字的表TEST被删除了,此时闪回被DROP的表TEST,实质是闪回最后一个被删除的表(后进先出原则),如果此时继续闪回操作就会报ORA-38312错误
此时可以在闪回过程中对表名进行重命名解决问题。。
另外,如果回收站有两个被DROP掉的表TEST,如果想闪回第一个被删除的表,那该怎么办呢?
其实这个也很好处理,直接指定RECYCLEBINNAME进行闪回即可。
清空回收站
数据库对象删除后,数据库会把它重命名为BIN$开头的对象,你可以通过ORIGINAL_NAME查看它对应的原始对象名称。记住,将表放在回收站里并不在原始表空间中释放空间。如果您希望完全删除该表,而不让该表放入回收站,可以使用以下命令永久删除该表。当然这样操作后,你也不能通过使用闪回特性闪回该表了。
DROPTABLETABLE_NAMEPURGE;
如果数据库中删除表时都放入回收站,因而没有释放所占空间,那么当空闲的空间不足时,已经删除的表是否还会侵占存储空间呢?
答案很简单:当表空间被回收站数据完全占满,以至于必须扩展数据文件来容纳更多数据时,可以说表空间处于“空间压力”情况下。此时,对象以先进先出的方式从回收站中自动清除。在删除表之前,相关对象(如索引)被删除。
同样,空间压力可能由特定表空间定义的用户限额而引起。表空间可能有足够的空余空间,但用户可能将其在该表空间中所分配的部分用完了。在这种情况下,Oracle自动清除该表空间中属于该用户的对象。
此外,有几种方法可以手动控制回收站。如果在删除名为TEST的特定表之后需要从回收站中清除它,可以执行
PURGETABLETABLE_NAME;
或者使用其回收站中的名称:
PURGETABLE"BIN$04LhcpndanfgMAAAAAANPw==$0";
此命令将从回收站中删除表TEST及所有相关对象,如索引、约束等,从而节省了空间。但是,如果要从回收站中永久删除索引,则可以使用以下命令来完成工作:
PURGEINDEXIN_TEST1_O1;
此命令将仅仅删除索引,而将表的拷贝留在回收站中。有时在更高级别上进行清除可能会有用。例如,您可能希望清除表空间USERS的回收站中的所有对象。可以执行:
PURGETABLESPACEUSERS;
您也许希望只为该表空间中特定用户清空回收站。在数据仓库类型的环境中,用户创建和删除许多临时表,此时这种方法可能会有用。您可以更改上述命令,限定只清除特定的用户:
PURGETABLESPACEUSERSUSERSCOTT;
要释放整个回收站占用的空间,您需要使用以下命令清空回收站:
PURGERECYCLEBIN;
记住PURGERECYCLEBIN只是清除当前用户回收站中的对象,DBA_RECYCLEBIN下的的对象并没有删除,如果你要清除当前数据库回收站的对象,必须使用下面命令(DBA权限)
PURGEDBA_RECYCLEBIN
FlashbackDrop注意事项
1:只能用于非系统表空间和本地管理的表空间。
如下所示,在系统表空间中,表对象删除后就真的从系统中删除了,而不是存放在回收站中。
2:对象的参考约束不会被恢复,指向该对象的外键约束需要重建。
3:对象能否恢复成功,取决于对象空间是否被覆盖重用。
4:当删除表时,依赖于该表的物化视图也会同时删除,但是由于物化视图并不会放入recyclebinzhong,因此当你执行flashbackdrop时,
并不能恢复依赖其的物化视图。需要DBA手工重建。
5:对于回收站(RecycleBin)中的对象,只支持查询。不支持任何其他DML、DDL等操作。
参考资料:
http://blog.csdn.net/tianlesoftware/article/details/4677378
http://www.cnblogs.com/kerrycode/p/4008362.html
从ORACLE10g开始,引入了一个叫回收站(RecycleBin)的概念。它的全称叫TablespaceRecycleBin。回收站实际是一个逻辑容器(逻辑区域),原理有点类似于WINDOW系统的回收站。它以表空间中现有已经分配的空间为基础,而不是从表空间上物理划出一个固定区域用作回收站。这意味着回收站和表空间中的对象共用存储区域、系统没有给回收站预留空间。因此,当表被DROP后,如果可用空间充足,并且没有对回收站进行清理,那么被DROP掉的对象会一直存在回收站中,但是如果可用空间紧张的情况下,数据库会根据先进先出的顺序覆盖Recycle
Bin中的对象。所以回收站机制也不是百分百的保险机制。另外从原理上来说它就是一个数据字典表,放置用户Drop掉的数据库对象信息。用户进行Drop操作的对象并没有真正被数据库删除,仍然会占用空间。除非是由于用户手工进行Purge或者因为存储空间不够而被数据库清掉。数据库有了这样的功能,能够减少很多不必要的麻烦。当用户、开发人员、甚至DBA误操作删除了表,那么我们不必还原整个数据库或表空间,直接使用ORACLE10g的闪回(FLASHBACK,闪回)功能来还原被删除的表。这样我们就能避免大量的人工误操作。这是一个对DBA相当有用的功能。
回收站功能
回收站这个特性主要的好处就是在误删除一个表时有一个恢复机制,不必通过数据库还原来实现。避免大量的人工误操作。以及数据库还原等复杂的操作。让数据库的管理、维护更加简单、方便。如果是SQLSERVER数据库,就必须还原整个数据库来找到被DROP掉的表。可见回收站功能确实是一个开创性的功能。
管理回收站
开启、关闭回收站
首先你可以通过命令查看数据库是否开启了回收站机制,如下所示VALUE=ON表示开启了回收站机制。OFF则表示回收站机制关闭。
SQL>SHOWPARAMETERRECYCLEBIN;
NAMETYPEVALUE
-----------------------------
recyclebinstringON
或
SQL>SELECTNAME,VALUEFROMV$PARAMETERWHERENAME='recyclebin';
NAMEVALUE
-------------------------------------
recyclebinon
可以通过设置初始化参数recyclebin启用或禁用回收站功能。当然也可以用命令关闭回收站
SQL>ALTERSYSTEMSETRECYCLEBIN=OFF;
Systemaltered.
SQL>ALTERSESSIONSETRECYCLEBIN=OFF;
Sessionaltered.
SQL>SHOWPARAMETERRECYCLEBIN;
NAMETYPEVALUE
-----------------------------------------------------------------------------
recyclebinstringOFF
可以用命令开启回收站
SQL>ALTERSYSTEMSETRECYCLEBIN=ON;
Systemaltered.
SQL>ALTERSESSIONSETRECYCLEBIN=ON;
Sessionaltered.
SQL>SHOWPARAMETERRECYCLEBIN;
NAMETYPEVALUE
-----------------------------------------------------------------------------
recyclebinstringON
查看回收站对象
我们先来看看一个例子,如下所示,假如不小心误操作DROP了表test,那么我们如何在回收站查看被DROP的表对象呢?
SQL>showuser
USERis"ODS"
SQL>createtabletest(namevarchar2(16));
Tablecreated.
SQL>insertintotestselect'kerry'fromdual;
1rowcreated.
SQL>insertintotestselect'ken'fromdual;
1rowcreated.
SQL>commit;
Commitcomplete.
SQL>droptabletest;
Tabledropped.
SQL1:
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vltN3TgUKjAgYxoiA==$0TABLE2014-10-06:11:25:38
SQL2: 其中RECYCLEBIN是USER_RECYCLEBIN的同义词。
COLOBJECT_NAMEFORA30
COLORIGINAL_NAMEFORA8
COLOPERATIONFORA9
COLTYPEFORA8
COLDROPTIMEFORA19
COLTS_NAMEFORA30
SELECTOBJECT_NAME
,ORIGINAL_NAME
,OPERATION
,TYPE
,DROPTIME
,TS_NAME
FROMRECYCLEBIN;
或
--查看数据库当前用户的回收站对象
SQL>SELECT*FROMRECYCLEBIN
SQL3:
--查看数据库当前用户的回收站对象
SQL>SELECT*FROMUSER_RECYCLEBIN;
SQL4: 需要相关权限才能查询。
--查看数据库回收站所有对象
SQL>SELECT*FROMDBA_RECYCLEBIN;
为了避免被删除的表与同类对象名称的重复,被删除的表以及相依的对象放到回收站后,ORACLE数据库会对被删除的对象名称进行重命名,例如表TEST表
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vltN3TgUKjAgYxoiA==$0TABLE2014-10-06:11:25:38
我们又创建了表TEST,然后删除了该表TEST,如下所示,虽然ORIGINAL_NAME一致,但是RECYCLEBINNAME则有所不同。
SQL>createtabletest(namevarchar2(16));
Tablecreated.
SQL>droptabletest;
Tabledropped.
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vluN3TgUKjAgYxoiA==$0TABLE2014-10-06:14:40:52
TESTBIN$BLmi9vltN3TgUKjAgYxoiA==$0TABLE2014-10-06:11:25:38
RECYCLEBINNAME的命名规则为BIN$GUID$Version其中GUID为GlobalUID,是一个全局唯一、24个字符长的标识对象,它是ORACLE内部使用的标识。其中$version是ORACLE数据库分配的版本号。
还原回收站对象
还原回收站被删除的表、索引等对象,是通过FlashbackDrop实现的。如下所示。
SQL>FLASHBACKTABLETESTTOBEFOREDROP;
Flashbackcomplete.
SQL>SELECT*FROMTEST;
NAME
----------------
kerry
ken
但是如果出现上面两个TEST表都被删除时,此时的FlashbackDrop就有点意思了
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vlxN3TgUKjAgYxoiA==$0TABLE2014-10-06:15:10:25
TESTBIN$BLmi9vlwN3TgUKjAgYxoiA==$0TABLE2014-10-06:15:10:09
SQL>flashbacktabletesttobeforedrop;
Flashbackcomplete.
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vlwN3TgUKjAgYxoiA==$0TABLE2014-10-06:15:10:09
SQL>select*fromtest;
norowsselected
如上所示,如果两个相同名字的表TEST被删除了,此时闪回被DROP的表TEST,实质是闪回最后一个被删除的表(后进先出原则),如果此时继续闪回操作就会报ORA-38312错误
SQL>flashbacktabletesttobeforedrop;
flashbacktabletesttobeforedrop
*
ERRORatline1:
ORA-38312:originalnameisusedbyanexistingobject
此时可以在闪回过程中对表名进行重命名解决问题。。
SQL>flashbacktabletesttobeforedroprenametotest_2;
Flashbackcomplete.
SQL>select*fromtest_2;
NAME
----------------
kerry
ken
另外,如果回收站有两个被DROP掉的表TEST,如果想闪回第一个被删除的表,那该怎么办呢?
SQL>showrecyclebin
ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME
-----------------------------------------------------------------------------
TESTBIN$BLmi9vlxN3TgUKjAgYxoiA==$0TABLE2014-10-06:15:10:25
TESTBIN$BLmi9vlwN3TgUKjAgYxoiA==$0TABLE2014-10-06:15:10:09
其实这个也很好处理,直接指定RECYCLEBINNAME进行闪回即可。
SQL>flashbacktable"BIN$BLmi9vlwN3TgUKjAgYxoiA==$0"tobeforedrop;
清空回收站
数据库对象删除后,数据库会把它重命名为BIN$开头的对象,你可以通过ORIGINAL_NAME查看它对应的原始对象名称。记住,将表放在回收站里并不在原始表空间中释放空间。如果您希望完全删除该表,而不让该表放入回收站,可以使用以下命令永久删除该表。当然这样操作后,你也不能通过使用闪回特性闪回该表了。
DROPTABLETABLE_NAMEPURGE;
如果数据库中删除表时都放入回收站,因而没有释放所占空间,那么当空闲的空间不足时,已经删除的表是否还会侵占存储空间呢?
答案很简单:当表空间被回收站数据完全占满,以至于必须扩展数据文件来容纳更多数据时,可以说表空间处于“空间压力”情况下。此时,对象以先进先出的方式从回收站中自动清除。在删除表之前,相关对象(如索引)被删除。
同样,空间压力可能由特定表空间定义的用户限额而引起。表空间可能有足够的空余空间,但用户可能将其在该表空间中所分配的部分用完了。在这种情况下,Oracle自动清除该表空间中属于该用户的对象。
此外,有几种方法可以手动控制回收站。如果在删除名为TEST的特定表之后需要从回收站中清除它,可以执行
PURGETABLETABLE_NAME;
或者使用其回收站中的名称:
PURGETABLE"BIN$04LhcpndanfgMAAAAAANPw==$0";
此命令将从回收站中删除表TEST及所有相关对象,如索引、约束等,从而节省了空间。但是,如果要从回收站中永久删除索引,则可以使用以下命令来完成工作:
PURGEINDEXIN_TEST1_O1;
此命令将仅仅删除索引,而将表的拷贝留在回收站中。有时在更高级别上进行清除可能会有用。例如,您可能希望清除表空间USERS的回收站中的所有对象。可以执行:
PURGETABLESPACEUSERS;
您也许希望只为该表空间中特定用户清空回收站。在数据仓库类型的环境中,用户创建和删除许多临时表,此时这种方法可能会有用。您可以更改上述命令,限定只清除特定的用户:
PURGETABLESPACEUSERSUSERSCOTT;
要释放整个回收站占用的空间,您需要使用以下命令清空回收站:
PURGERECYCLEBIN;
记住PURGERECYCLEBIN只是清除当前用户回收站中的对象,DBA_RECYCLEBIN下的的对象并没有删除,如果你要清除当前数据库回收站的对象,必须使用下面命令(DBA权限)
PURGEDBA_RECYCLEBIN
FlashbackDrop注意事项
1:只能用于非系统表空间和本地管理的表空间。
如下所示,在系统表空间中,表对象删除后就真的从系统中删除了,而不是存放在回收站中。
SQL>showuser
USERis"SYS"
SQL>createtabletest(namevarchar2(12));
Tablecreated.
SQL>droptabletest;
Tabledropped.
SQL>showrecyclebin;
2:对象的参考约束不会被恢复,指向该对象的外键约束需要重建。
3:对象能否恢复成功,取决于对象空间是否被覆盖重用。
4:当删除表时,依赖于该表的物化视图也会同时删除,但是由于物化视图并不会放入recyclebinzhong,因此当你执行flashbackdrop时,
并不能恢复依赖其的物化视图。需要DBA手工重建。
5:对于回收站(RecycleBin)中的对象,只支持查询。不支持任何其他DML、DDL等操作。
参考资料:
http://blog.csdn.net/tianlesoftware/article/details/4677378
http://www.cnblogs.com/kerrycode/p/4008362.html
相关文章推荐
- ORACLE回收站机制介绍
- ORACLE回收站机制介绍及管理
- ORACLE回收站机制介绍
- ORACLE回收站机制介绍
- oracle的回收站介绍
- Oracle的hints调整机制介绍
- Oracle的回收站和闪回查询机制(一)
- Oracle的回收站和闪回查询机制(二)
- Oracle的回收站和闪回查询机制(一)
- Oracle的回收站和闪回查询机制(二)
- 理解redo(7)oracle redo并行机制的原理介绍
- 理解redo(7)oracle redo并行机制的原理介绍 .
- Oracle RAC/Clusterware 多种心跳heartbeat机制介绍 RAC超时机制分析
- 全面介绍Windows内存管理机制及C++内存分配实例
- 0080 Oracle 11g服务详细介绍及哪些服务是必须开启的?【基础】
- 这篇文章主要介绍了ThinkPHP的MVC开发机制实例解析
- 清空Oracle回收站
- cx_Oracle模块介绍
- 06-Oracle权限传递、角色管理、三种验证机制
- ORACLE 内部运行机制图解