oracle闪回技术(Flashback)

本文介绍了Oracle数据库中的闪回技术,这是一种使数据恢复变得简单、快捷且可靠的方法。文章详细解释了如何通过回收站(recyclebin)机制来实现表的删除与恢复,并提供了开启闪回功能及操作回收站的相关SQL命令。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle使用了革命一的技术来形容它在Oracle 10g中引入的闪回技术。这一技术在某些情况下确实使数据的恢复变得非常简单、快捷而且可靠。

        闪回技术是这样处理的:当一个表被删除时,它并不是真的被删除了,而只是被放到了回收站(recyclebin)里了,只要这表还在回收站里,它就可以被重新恢复(闪回)回来。该回收站被放在所在的表空间,Oracle并不保证所有删除的表都能闪回成功。因为当用户在某个表空间上创建一个新表时,Oracle首先使用空闲的磁盘空间,如果没有足够的磁盘空间,Oracle将使用回收站的磁盘空间。因此在创建表空间时最好留出足够的磁盘空间以方便日后进行恢复工作。

要使Oracle能够使用这一技术,DBA还需要将系统参数recyclebin设置为ON。

flashback相关语法:

-----------------查看recyclebin的值(flashblack是否打开)-----------------

show parameter bin;

 

-----------------打开flashblack功能(修改参数值on为打开,off为关闭)-----------------

alter system set recyclebin=on;

 

-----------------显示被删除的表-----------------

show recyclebin;

 

-----------------清除回收站里的表,table_name为表名(original name)-----------------

purge table表名;

 

-----------------清除回收站里所有的表-----------------

purge recyclebin;

 

-----------------从回收站恢复表-----------------

flashback table 表名 to before drop;

 

-----------------直接删除一张表,(不到回收站)-----------------

drop teble 表名 purge;

提示:

闪回技术只能保护非系统表空间中的表,而且这些表还必须存放在本地管理的表空间中。尽管在一个表被删除时,依赖于该表的绝大多数对象也受到回收站的保护,但是位图、引用完整性约束等并不受到回收站的保护。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值