`
哇哈哈852
  • 浏览: 91507 次
文章分类
社区版块
存档分类
最新评论

Oracle 回收站recyclebin

阅读更多


racle10g Recycle Bin回收站

1>什么是Recycle Bin

实际上,Recycle Bin只是一个保存被drop的对象的一个数据字典表。所以,可以通过如下语句查询回收站中的信息:
select * from recyclebin

除非拥有sysdba权限,每个用户只能看到属于自己的对象。所以,对于用户来说,好像每个人都拥有自己的回收站。即使用户有删除其他schema对象的权限,也只能在recyclebin中看到属于自己的对象。

做个小试验:
SQL> conn ning/ning
已连接。
SQL> drop table test;


表已删除。


SQL> drop table test.test;
表已删除。


SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$xJlIkIFVR/yau1Qb8ocxxQ==$0 TEST


SQL> con test/test
已连接。


SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$1PKEiRExRN2g3tqEEWLfyw==$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> create table t(id int);


表已创建。


SQL> drop table t;


表已删除。
SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$+7J5MgT2RbCX+tka+zjpgA==$0 T


SQL> create table t(id int);


表已创建。


SQL> drop table t;


表已删除。


SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$+7J5MgT2RbCX+tka+zjpgA==$0 T
BIN$pc+kkUM7QjuQeCDGtwlzgQ==$0 T


可以看到,删除table t后,重建一个名为t的table,再次删除,其unique_id是不一样的。


这时,做一个还原看看:


SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$+7J5MgT2RbCX+tka+zjpgA==$0 T


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


再次删除:
SQL> drop table t;


表已删除。
SQL> select object_name,original_name from recyclebin;


OBJECT_NAME ORIGINAL_NAME
------------------------------ --------------------------------
BIN$4bNgZiMGTA63iwA5xflh5A==$0 T
BIN$+7J5MgT2RbCX+tka+zjpgA==$0 T


可以看到unique_id又变了。所以,通过这种命名方式,避免了对于删除table后又重建了同名table的情况可能造成的命名冲突。


2.如何启用/禁用RecycleBin


通过设置初始化参数recyclebin,可以控制是否启用回收站功能,默认是开启的。
SQL> alter system set recyclebin=off;


系统已更改。


SQL> alter system set recyclebin=on;


系统已更改。


SQL> alter session set recyclebin=off;


会话已更改。


SQL> alter session set recyclebin=on;


会话已更改。
  • 大小: 27.8 KB
分享到:
评论

相关推荐

    Oracle回收站空间清空.doc

    Oracle 回收站空间清空 Oracle 回收站是一种特殊的存储区域,用于存储已删除的表和对象。它可以帮助用户快速恢复误删除的表和对象,避免数据丢失。下面是关于 Oracle 回收站的知识点: 1. 查看回收站:使用 SELECT...

    oracle新手入门指导之六—ORACLE回收站详解.txt

    ### Oracle新手入门指导之六——Oracle回收站详解 #### 回收站概念介绍 在Oracle数据库中,**回收站(Recycle Bin)**是一项非常实用的功能,它为用户提供了一种安全删除对象的方式。当用户删除一个表、视图、索引等...

    Oracle从回收站恢复删除的表

    ### Oracle从回收站恢复删除的表 #### 一、引言 在Oracle 10g及后续版本中,为了提供更高效的数据管理能力,引入了一个非常实用的功能——**回收站**(Recycle Bin)。这一特性使得数据库管理员能够在不慎删除表等...

    Oracle 回收站功能,彻底删除表ORA-00933:SQL command not properly ended

    ### Oracle回收站功能详解与彻底删除表方法 #### 一、Oracle回收站功能概述 Oracle数据库自10g版本开始引入了回收站功能(Recycle Bin),这一特性为数据库管理员提供了一种简单而强大的方式来恢复误删的数据对象。...

    Oracle 闪回特性 FLASHBACK & RECYCLEBIN

    Flashback Drop 的实现是基于 Oracle 的 RECYCLEBIN 机制,该机制可以将被删除的表重命名并放入回收站中,可以随时恢复。 6. Flashback Version Query Flashback Version Query 是 Flashback 系列中的一种功能,...

    BLOG_Oracle 回收站及flashback drop_LHR.pdf

    在了解Oracle回收站的功能和操作之前,有必要掌握以下知识点: 1. Oracle回收站的开启、关闭和清空: - 开启回收站:在Oracle数据库中,回收站默认是开启的。如果需要确认回收站状态或者开启回收站,可以使用如下...

    关于oracle的Recycle Bin回收站

    Oracle 10g 的 Recycle Bin 回收站 Oracle 10g 引入了 Recycle Bin 回收站功能,类似于操作系统中的回收站。当用户 drop table 时,实际上只是将其重命名,并将 table 以及相关联的对象如 index、constraint 等放到...

    关于oracle10供了类似操作系统中的回收站功能

    Oracle 10g 引入的回收站(Recycle Bin)功能是数据库管理的一大进步,它为用户提供了一种类似于操作系统中的回收站机制,允许用户在误删数据库对象后有机会恢复。这一特性显著减少了因人为错误导致的数据丢失问题,...

    oracle10g回收站研究

    Oracle 10g 的回收站功能是一个内置的数据保护机制,允许数据库管理员恢复意外删除的表、索引和其他数据库对象。回收站本质上是一个特殊区域,它保存了被删除对象的元数据,直到它们被显式地从回收站中清除或者达到...

    ORACLE 回收站当前状态查询整理

    了解并掌握Oracle回收站的使用对于数据库管理员来说至关重要,因为它提供了对误删对象的保护措施,能够在不丢失数据的情况下快速恢复错误操作,避免了潜在的生产环境风险。然而,需要注意的是,回收站虽然方便,但也...

    Oracle 10G中的回收站

    Oracle 10G的回收站是数据库管理系统中一个重要的特性,它允许用户在不小心删除数据库对象后能够方便地恢复这些对象,从而极大地减少了因误操作导致的数据丢失问题。回收站本质上是一个数据字典表,存储了被Drop操作...

    Oracle10g数据库回收站的管理与维护.pdf

    【Oracle10g数据库回收站】是Oracle 10g版本引入的一个重要特性,它提供了一种方便的数据恢复机制,允许用户撤销误删除的操作。在早期的Oracle版本中,一旦执行了DROP TABLE命令,表及其相关数据将永久丢失,恢复...

    Oracle数据库误删除数据的不同恢复方法整理

    - **原理**:当使用`DROP`命令删除表后,Oracle并没有立即清除表占用的空间,而是将其放入了一个特殊的区域——回收站中,直到这些空间被新的数据覆盖。 - **查询回收站**:可以通过查询`USER_TABLES`视图或`USER_...

    彻底删除 Oracle 的数据表

    Oracle回收站是数据库的一个特殊区域,用于存放被删除的对象。这些对象包括但不限于表、索引等。当对象被放入回收站后,它们的状态会被标记为已删除,但仍保留着原始的结构和数据。这意味着,即使这些对象不再占用...

    彻底删除和闪回oracle表

    Oracle数据库中的删除操作并不像我们通常理解的那样立即清除数据,而是将被删除的对象移动到回收站(Recyclebin)中。回收站是Oracle提供的一种安全机制,它允许用户在误删数据后有机会进行恢复,这也就是所谓的“闪...

    oracle 误删除表恢复

    本文将详细介绍如何在Oracle环境下利用回收站功能进行误删表的恢复。 ### 回收站功能简介 Oracle自10g版本起引入了回收站(Recycle Bin)的概念,这一特性允许用户恢复已删除的对象,包括表、索引等。通过回收站...

    Oracle数据库误删除数据的不同恢复方法整理(超级实用)

    为了应对这种情况,Oracle提供了多种数据恢复的方法,包括闪回恢复、从回收站恢复等。本文将详细介绍这些方法,并给出具体的实施步骤。 #### 二、误删除数据恢复概述 ##### 2.1 闪回恢复 **闪回恢复**是Oracle提供...

    Oracle管理 | 回收站

    Oracle数据库的回收站功能是一个非常重要的特性,它允许数据库管理员在不小心删除了对象后能够进行恢复,避免数据丢失。回收站本质上是一个系统级别的全局临时存储区域,保存了被删除但未被永久清除的表、索引等...

    快速掌握删除Oracle 10g垃圾表的好方法

    这些表通常具有类似"BINjR8PK5HhrrgMK8KmgQ9nw=="这样的随机字符串作为名称,它们实际上是Oracle 10g引入的新特性——回收站(Recyclebin)功能的结果。回收站功能为用户提供了一种撤销误删操作的安全机制,但同时也...

Global site tag (gtag.js) - Google Analytics