oracle中recyclebin的原理具体是?

解决方案 »

  1.   

    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的对象清除 
      

  2.   

    这东西需要什么原理?
    无非就是从oracle10g开始,增加了一个逻辑删除功能呗当recyclebin 打开的时候,逻辑删除,同时修改表名
    oracle正常读取的是非逻辑删除的表这个跟windows的回收站木有太大的区别。
      

  3.   

    在oracle 10g引入了recyclebin,对于一个对象的删除,oracle先通过修改数据字典,将其及其关联对象(索引、约束等)重命名,然后放入recyclebin。被删除的对象将占用创建时的同样的空间大小,当出现空间压力时,这个空间才会被慢慢回收。但是当对象被删除之后,这部分空间会计入free space,被看作是自由空间,可重用,在dba_free_space可查。如果能够确认删除对象,则可以使用purge命令完全删除,这样可以减少动态空间回收带来的性能代价。          每个用户都有属于自己的一个recyclebin。查看recyclebin的方法很多,最常用的是select * from recyclebin;最简单的是show recyclebin。需要注意的是show recyclebin只列出基表,被删除的表的关联对象则不显示。recyclebin里对象的名称也可以被当做普通名称一样使用,唯一区别是,无法被rename。           ● 表空间无足够的空闲空间,并且没有新的空间可作扩展操作
              ● 该表空间又要创建新的对象,需要分配空间
              在这种情形下就会造成recyclebin的空间压力,这是触发recyclebin主动删除对象的唯一原因
      

  4.   


    rename 木有问题,你用的神马版本?
      

  5.   

    惭愧啊、早起刷分果断不是好事
    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