文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle中如何恢复错误修改删除的数据

2024-04-02 19:55

关注

小编给大家分享一下oracle中如何恢复错误修改删除的数据,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

Oracle ERP维护人员工作再小心也难免会有在正式库中误删或者误改数据并且已经commit的情况发生,那么我就要用到 - Oracle9i中的FlashBack功能,或许很多同事们都在用,下面我谈谈我在使用中的方法和一些感想:
具体方法如下 >>
1. 我们可以使用
  SELECT item_cost FROM cst_item_costs
      AS OF TIMESTAMP (SYSTIMESTAMP - INTERVAL '1' hour)
      WHERE organization_id = 1
      AND yyyymm = 200712
      AND item_number = '6384BLCCSL';
  来查看1个小时前的数据.
  * 这里需要说明几点:
    a. AS OF TIMESTAMP expr 是SELECT语句中的FLASHBACK子句
    b. SYSTIMESTAMP 是系统提供的时间函数,精确度可以达到微秒级,并提供当前时区
      eg. select SYSTIMESTAMP from dual;
          SYSTIMESTAMP                                                              
          ---------------------------------------------------------------------------
          29-DEC-07 11.16.08.112686 AM +09:00
    c. INTERVAL 的作用是用来指定时间区间,下面是它参与运算的法则
       Operand1         Operator         Operand2         Result Type
       -------------------------------------------------------
       Datetime        -                Interval        Datetime
       
       我们可以通过修改时间单位和数量来改变倒退时间
      eg. TIMESTAMP (SYSTIMESTAMP - INTERVAL '1' day) --查询一天前的数据
          TIMESTAMP (SYSTIMESTAMP - INTERVAL '10' minute ) --查询十分钟前的数据
          TIMESTAMP (SYSTIMESTAMP - INTERVAL '50' second ) --查询50秒前的数据
   d. 关于在FlashBack中的可回朔时间
       Oracle中有两个参数能够决定可回朔时间 >>
             undo 表空间大小 和 undo_retention 初始化参数.
             一般的ERP正式系统里面的 undo tablespace 为 20G左右, undo_retention设置为 3600S.
             业务繁忙时间最大可回朔时间约为 2-3h,非业务时间为4-5h,这里需要注意: 最大可回朔时间是由
        undo表空间大小及数据库数据变更的频繁程度来决定的.
            如果超过最大可回朔时间时,系统会给出有名的 ORA-01555 快照太老(Snapshot too old)错误.
     e. 做FlashBack必须要有 FlashBack Any Table 的系统权限.
         
2. 那么依此类推,我们就可以利用FlashBack来恢复某段时间前的数据了
  UPDATE cst_item_costs SET item_cost =      
  (SELECT item_cost FROM cst_item_costs
  AS OF TIMESTAMP (SYSTIMESTAMP - INTERVAL '1' hour)
  WHERE organization_id = 1
      AND yyyymm = 200712
      AND item_number = '6384BLCCSL)
  WHERE organization_id = 1
      AND yyyymm = 200712
      AND item_number = '6384BLCCSL';
  * 这里也要说明几点:
    a. 在恢复数据前,要检查WHERE条件是否具有唯一性
  b. 如果要成批恢复或全表恢复数据的话,要检查是否在指定的时间区间内还有其他会话写入的数据

看完了这篇文章,相信你对“oracle中如何恢复错误修改删除的数据”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯