网站公告列表

  没有公告

加入收藏
设为首页
联系站长
您现在的位置: 天盾数据恢复中心 >> 文章中心 >> 数据库技术 >> 文章正文
  用Oracle闪回功能恢复偶然丢失的数据         ★★★ 【字体:
用Oracle闪回功能恢复偶然丢失的数据
作者:佚名    文章来源:转贴    点击数:    更新时间:2007-1-24    
SQL> create user flashtest identified by flashtest;

SQL> grant connect, resource to flashtest;

SQL> grant execute on dbms_flashback to flashtest;

SQL> connect flashtest/flashtest;

  (2)创建测试表,插入测试记录

SQL> create table test(id number(3));

SQL> insert into test values (1);

SQL> insert into test values(2);

SQL> commit;

SQL> create table rec_date(date_scn);

  注意:在执行步骤3或者步骤4之前,等待5分钟。

  (3)删除记录

SQL> execute dbms_flashback.disable;

SQL> insert into rec_date select sysdate from dual;

SQL> commit;

SQL> delete from test where id=1;

SQL> commit;

  通过以上的操作,我们插入了两条记录,并删除了其中一条记录。在以下的操作中,我们将通过flashback query找到删除的记录

  (4)闪回查询

SQL> DECLARE

Restore_scn date;

BEGIN

Select date_scn into restore_scn from rec_date;

Dbms_flashback.enable_at_time (restore_scn);

END;

SQL> select * from test;

ID

1

2


  可以看出,虽然删除记录并提交,但是通过闪回操作,仍能查询到删除前的两条记录。需要注意Oracle每5分钟记录一次SCN,并将SCN和对应时间的映射进行纪录。如果原来插入的记录到做闪回操作的时间在5分钟之内,用基于时间的闪回查询可能得不到记录,因为基于时间点的查询实际上是转化为最近的一次SCN,然后从这个SCN开始进行恢复。因此,如果需要精确的查询可以采用基于SCN的闪回查询,可精确闪回到需要恢复的时间。可以通过DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER语句获取SCN。
文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章: 没有了
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    Microsoft SQL Server 7.0 备
    SQL Server崩溃时如何恢复
    SQL Server数据库备份和恢复
    Microsoft SQL Server数据库
    SQL Server2000数据库文件损
    SQL Server 数据库的备份与恢
    轻松修复软Raid故障
    RAID技术深度剖析
    RAID0、RAID1、RAID0+1、RAI
    存储基础知识:磁盘阵列技术
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    Copyright © 2006 huifu119.com, All rights reserved. 站长: