设为首页 收藏本站
查看: 1041|回复: 0

[经验分享] Oracle Flashback技术总结(二)—— Flashback DROP

[复制链接]

尚未签到

发表于 2016-8-3 15:36:13 | 显示全部楼层 |阅读模式
二、FlashbackDROP

FlashbackDrop是从Oracle10g开始出现的,用于恢复用户误删除的对象(包括表,索引等),这个技术依赖于TablespaceRecycleBin(表空间回收站),这个功能和windows的回收站非常类似。
Flashback不支持system表空间下的对象,不能从回收站里拿到。故使用SYS或者SYSTEM用户登陆时,showrecyclebin为空。
Flashback table语法:
DSC0000.jpg

1. Flashback Drop 设置

从Oracle10g开始,每个表空间都会有一个叫作回收站的逻辑区域,当用户执行drop命令时,被删除的表和表的关联对象(包括索引,约束,触发器,LOB段,LOBindex段)不会被物理删除,这些对象先转移到回收站中,这就给用户提供了一个恢复的可能。

初始化参数recyclebin用于控制是否启用recyclebin功能,缺省是ON,可以使用OFF关闭。



SQL>showparameterrecycle



NAMETYPEVALUE

-----------------------------------------------------------------------------

buffer_pool_recyclestring

db_recycle_cache_sizebiginteger0

recyclebinstringon



禁用该功能:

SQL>altersystemsetrecyclebin=off; (10g)

SQL>altersystemsetrecyclebin=on;(10g)
SQL>alter system set recyclebin=off deferred; ( 11g ,deferred表示延时,需要重启以后生效)
SQL>alter system set recyclebin=on deferred;  (11g)

SQL>altersessionsetrecyclebin=off; (10/11g)

SQL>altersessionsetrecyclebin=on;(10/11g)



禁用后删除的对象将直接删除,不会写到Recycle中,当然在删除时,指定

purge参数,表也将直接删除,不会写到recyclebin中。
     SQL>droptablenamepurge;



查看recyclebin中的对象列表:


SQL>select*fromA;

ID

----------

1

2

3

SQL>droptableA;

表已删除。

SQL>showrecyclebin

ORIGINALNAMERECYCLEBINNAMEOBJECTTYPEDROPTIME

----------------------------------------------------------------------------



ABIN$RWXQQcTPRde0ws4h9ewJcg==$0TABLE2009-10-15:12:44:33



查看recyclebin中对象:


SQL>selectoriginal_name,object_namefromrecyclebin;



ORIGINAL_NAMEOBJECT_NAME

--------------------------------------------------------------

ABIN$RWXQQcTPRde0ws4h9ewJcg==$0



查看recyblebin对象里的内容:


SQL>select*from"BIN$RWXQQcTPRde0ws4h9ewJcg==$0";

ID

----------

1

2

3

表空间的RecycleBin区域只是一个逻辑区域,而不是从表空间上物理的划出一块区域固定用于回收站,因此RecycleBin是和普通对象共用表空间的存储区域,或者说是RecycleBin的对象要和普通对象抢夺存储空间。当发生空间不够时,Oracle会按照先入先出的顺序覆盖RecycleBin中的对象。也可以手动的删除RecycleBin占用的空间。



  • Purgetablespacetablespace_name:用于清空表空间的RecycleBin
  • urgetablespacetablespace_nameuseruser_name:清空指定表空间的RecycleBin中指定用户的对象
  • Purgerecyclebin:删除当前用户的RecycleBin中的对象
  • Purgedba_recyclebin:删除所有用户的RecycleBin中的对象,该命令要sysdba权限
  • Droptabletable_namepurge:删除对象并且不放在RecycleBin中,即永久的删除,不能用Flashback恢复。
  

6).Purgeindexrecycle_bin_object_name:当想释放Recyclebin的空间,又想能恢复表时,可以通过释放该对象的index所占用的空间来缓解空间压力。因为索引是可以重建的。





2.FlashbackDrop实例操作


SYS@ orcl >select object_name,original_name from recyclebin;
OBJECT_NAME   ORIGINAL_NAME
------------------------------ --------------------------------
BIN$3VLF0vGPjivgQAB/AQASgw==$0 TEST009



SYS@ orcl >flashback table test009 to before drop;
Flashback complete.
SYS@ orcl >select * from test009;
  
  

当我们删除表A后,在新建表A,这时在恢复的时候就会报错,此时我们在闪回时,对表重命名就可以了:

SYS@ orcl >flashback table test010 to before drop rename to test011;

当我们删除表A,在新建表A,在删除它,这是在RecycleBin中就会有2个相同的表明,此时恢复我们就要指定object

_name才行.




SYS@ orcl >show recycle
ORIGINAL NAMERECYCLEBIN NAME OBJECT TYPE DROP TIME
---------------- ------------------------------ ------------ -------------------
TEST011BIN$3VLF0vGUjivgQAB/AQASgw==$0 TABLE 2013-05-23:00:24:10
TEST011BIN$3VLF0vGTjivgQAB/AQASgw==$0 TABLE 2013-05-23:00:23:21
TEST011BIN$3VLF0vGRjivgQAB/AQASgw==$0 TABLE 2013-05-23:00:20:41
  

flashback table "BIN$3VLF0vGRjivgQAB/AQASgw==$0" to before drop



一旦完成闪回恢复,RecycleBin中的对象就消失了.FlashbackDrop需要注意的地方:



  • 只能用于非系统表空间和本地管理的表空间
  • 对象的参考约束不会被恢复,指向该对象的外键约束需要重建。
  • 对象能否恢复成功,取决与对象空间是否被覆盖重用。
  • 当删除表时,信赖于该表的物化视图也会同时删除,但是由于物化视图并不会被放入recyclebin,因此当你执行flashbacktabletobeforedrop时,也不能恢复依赖其的物化视图,需要dba手工介入重新创建。
  • 对于RecycleBin中的对象,只支持查询.
  





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252379-1-1.html 上篇帖子: oracle 11g PL/SQL Programming学习二 下篇帖子: 一个菜鸟的oracle之路----一
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表