日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

oracle修改删除数据,[Oracle 错误修改删除数据后的恢复方法

發布時間:2025/4/5 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle修改删除数据,[Oracle 错误修改删除数据后的恢复方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

[Oracle ERP維護人員必備] 錯誤修改刪除數據后的恢復方法

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修改删除数据,[Oracle 错误修改删除数据后的恢复方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。