Oracle9i的Flashback查询

启用Oracle9i的Flashback查询
作者: ZDNet China
2005-01-07 12:12 PM

本文译自Builder.com,未经许可请勿转载

Oracle9i的Flashback查询的用途非常多。终端用户或者开发者几乎每天都要恢复那些由于应用失误造成的丢失数据或者被修改的数据。

<script language="JavaScript1.1" src="http://ad.cn.doubleclick.net/adj/messagingplus.zdnet.com.cn/developer/database;sz=1x1;ord=1215279092?" type="text/javascript"> </script>Click here to find out more!

Oracle宣称你可以用Flashback查询创建具有内嵌的、面向终端用户的、自服务的纠错能力的应用程序,但是很少有Oracle使用者打算去实现自服务纠错或者是要求DBA进行flashback恢复。

你可以使用DBMS_FLASHBACK包去启用或禁用Flashback查询。你还能使用系统改变数(SCN)或者真实时间来指定flashback的时间点。

例如,假设你在上午11:15对数据库作了一个不正确的改变。只要你的Flashback查询处于启用状态,你就能使用下面的命令告诉Oracle应用上午11:00时所有的undo日志映像:

EXECUTE dbms_Flashback.Enable_At_Time('28-AUG-02 11:00:00');

现在所有的查询都将显示上午11:00时的数据,你还可以很容易地恢复丢失的或者被修改的数据。

虽然这是及时回退一个显著的有用特征,但是还是有一些限制的:

  • 服务器必须配置成使用自动undo管理。
  • 在使用Flashback查询时不能使用DDL或者DML。
  • Flashback不取消DDL操作,例如DROP命令。

数据库管理员做一些必要的设置之后,一般用户才能使用Flashback查询功能,下面是所要做的设置:

  • ALTER SYSTEM SET UNDO_MANAGEMENT=AUTO
  • ALTER SYSTEM SET UNDO_RETENTION=86400
  • GRANT EXECUTE ON DBMS_FLASHBACK TO USERNAME;

UNDO_RETENTION的参数(单位为秒)指定Oracle保存用于flashback查询的undo映像的时间。一般你可以将这个值设为一整天(864000秒),这样你就能看到前一天全天的映像。当然,你的在线undo日志必须足够大,大到足以能保存一整天的undo日志数据,对于繁忙的Oracle系统,这个数值可以达到很多G字节。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值