亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

oracle中如何恢復錯誤修改刪除的數據

發布時間:2021-11-10 10:29:49 來源:億速云 閱讀:135 作者:小新 欄目:數據庫

小編給大家分享一下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中如何恢復錯誤修改刪除的數據”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

濮阳县| 博乐市| 宣化县| 桦南县| 策勒县| 赣榆县| 丹巴县| 吴桥县| 灯塔市| 习水县| 韩城市| 玛沁县| 麻阳| 阿克苏市| 林西县| 东光县| 扎兰屯市| 隆尧县| 新闻| 辛集市| 兴业县| 荣成市| 资讯| 宜城市| 朝阳县| 延长县| 阿尔山市| 德江县| 浑源县| 阳朔县| 崇文区| 福鼎市| 荥阳市| 广汉市| 盘锦市| 湖口县| 贡觉县| 新宾| 凤城市| 邳州市| 启东市|