婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Oracle數(shù)據(jù)庫數(shù)據(jù)丟失恢復的幾種方法總結

Oracle數(shù)據(jù)庫數(shù)據(jù)丟失恢復的幾種方法總結

熱門標簽:圖吧網(wǎng)站地圖標注 山東crm外呼系統(tǒng)軟件 哈爾濱電話機器人銷售招聘 百度地圖標注途經(jīng)點 愛客外呼系統(tǒng)怎么樣 開發(fā)外呼系統(tǒng) 地圖標注養(yǎng)老院 慧營銷crm外呼系統(tǒng)丹丹 哪個400外呼系統(tǒng)好

根據(jù)oracle數(shù)據(jù)庫的特點和提供的工具,主要方法有以下幾種方法:

  1.      利用邏輯備份使用import工具丟失數(shù)據(jù)的表
  2.      利用物理備份來通過還原數(shù)據(jù)文件并進行不完全恢復
  3.      利用dbms_logmnr包從redo log文件中恢復
  4.      利用flashback特性恢復數(shù)據(jù)

前提

為了方便使用方法的介紹,上述恢復方法都將基于以下場景進行:系統(tǒng)管理員在前一天晚上11點用export對數(shù)據(jù)庫做了全庫邏輯備份,然后對所有數(shù)據(jù)文件進行了熱備份。第二天上午10點,系統(tǒng)管理員在修改表TFUNDASSET的數(shù)據(jù)時,由于修改語句的條件寫錯了,導致一批記錄(幾千條)的ztm字段被修改成了錯誤的值,而且已經(jīng)提交。這個表是資產(chǎn)表,相對而言數(shù)據(jù)變化不頻繁。

一、利用邏輯備份使用import工具恢復丟失的數(shù)據(jù)

export/import是oracle提供的用于對數(shù)據(jù)庫進行邏輯備份的工具。該工具適用于備份那些數(shù)據(jù)量不大、業(yè)務量不多的數(shù)據(jù)庫系統(tǒng)。因為如果在前一天晚上11點用export做了邏輯備份,那么當今天上午10點數(shù)據(jù)庫意外崩潰時,從備份起到數(shù)據(jù)庫崩潰的這段時間里的數(shù)據(jù)修改操作(包括DDL和DML)都會丟失。如果丟失數(shù)據(jù)內的表上的數(shù)據(jù)是相對比較穩(wěn)定,也就是說該表上基本沒有DML操作,例如標準代碼表、分區(qū)表里的歷史數(shù)據(jù),那么采用import來導入該表可以比較完整的恢復數(shù)據(jù)。如果該表是經(jīng)常變化的業(yè)務表,那么這些丟失的數(shù)據(jù)只能根據(jù)業(yè)務情況從紙質記錄恢復,或者其他途徑恢復。

▲示例如下:這個表是一個資產(chǎn)表。相對來說,今天系統(tǒng)運行中修改的數(shù)據(jù)較少,丟失的數(shù)據(jù)量可以承受或者可以從別的途徑恢復。那就可以用import來恢復。

方法一:

1、把這個表的數(shù)據(jù)備份到另一個表:

2、刪除該表的記錄:

3、執(zhí)行下面的命令:

這個命令中在關鍵字tables中指定需要導入的表名字,ignore=y表示忽略表已經(jīng)存在的錯誤。

4、導入結束后,檢查表中的記錄,并用適當?shù)姆椒ɑ謴彤斕斓男薷摹?/p>

方法二:

1、 把需要恢復的表導入到另一個用戶下面:

2、檢查數(shù)據(jù)以后,把原表記錄刪除:

3、然后從另一用戶表中插入回去:

4、 數(shù)據(jù)量比較大時可以采用如下方法:

二、利用物理備份來通過還原數(shù)據(jù)文件并進行不完全恢復

如果數(shù)據(jù)庫運行在歸檔模式下,那么可以通過使用以前的數(shù)據(jù)文件備份進行還原,然后利用歸檔日志進行前滾,直到回滾到錯誤操作的時間點前,然后重置日志文件打開數(shù)據(jù)庫。

可以通過下列方法確認是否是運行在歸檔模式:

如果是如上所示,那么就是運行在歸檔模式了。

▲假定在前一天晚上11點做了全庫物理備份,那么可以考慮如下恢復:

1、關閉數(shù)據(jù)庫:

由于數(shù)據(jù)庫的不完全恢復必須在一個關閉的數(shù)據(jù)庫上實施,利用一個舊的數(shù)據(jù)庫的備份還原,然后用日志根據(jù)需要逐步前滾,而不能還原一個新的備份,再回退到某個時間點。

通知各客戶端數(shù)據(jù)庫將關閉,然后發(fā)出:

數(shù)據(jù)庫已經(jīng)關閉。

已經(jīng)卸載數(shù)據(jù)庫。

ORACLE 例程已經(jīng)關閉。

2、確定錯誤操作的時間:

可以根據(jù)操作員的估計來確定不完全恢復需要前滾停止的時間,也可以利用LogMiner來分析日志文件(這個工具將在后面介紹),找出錯誤操作的準確時間。

3、還原數(shù)據(jù)文件:

先對當前的數(shù)據(jù)庫文件進行備份,然后再用以前的最近一次備份覆蓋現(xiàn)有數(shù)據(jù)文件。注意:不覆蓋現(xiàn)有的控制文件。

4、基于時間點恢復,啟動數(shù)據(jù)庫到裝配狀態(tài):

這樣數(shù)據(jù)庫就恢復到了2015年10月20日的9點58分零秒。

然后再利用業(yè)務資料補充這段時間內的數(shù)據(jù)。

三、利用dbms_logmnr包從log文件中恢復

這個包是由Oracle提供,與dbms_logmnr_d包配合使用可以方便地分析聯(lián)機日志文件和歸檔日志文件,從這些日志文件中提取出所有對數(shù)據(jù)庫的更改操作。

在使用這個包之前,需要先做一些設置和修改:

1、打開initorcl.ora,修改初始化參數(shù)utl_file_dir,設置dbms_logmnr_d包將要使用的數(shù)據(jù)字典文件的放置目錄。

然后重啟數(shù)據(jù)庫使參數(shù)生效。

2、以sys用戶連接到數(shù)據(jù)庫執(zhí)行dbmslmd.sql腳本重建dbms_logmnr_d這個包。

應用Logminer分析重做日志文件的操作主要有以下步驟:

      ● 使用dbms_logmnr_d里的存儲過程build創(chuàng)建一個外部數(shù)據(jù)字典文件;

      ● 使用dbms_logmnr里的存儲過程add_logfile添加要分析的日志文件;

      ● 使用dbms_logmnr里的存儲過程start_logmnr啟動分析;

      ● 查詢與dbms_logmnr相關的幾個視圖來獲取日志文件內容;

      ● 使用dbms_logmnr里的存儲過程end_logmnr結束分析。

▲下面詳細講述使用的過程

1、使用dbms_logmnr_d里的存儲過程build創(chuàng)建一個外部數(shù)據(jù)字典文件:

2、使用dbms_logmnr里的存儲過程add_logfile添加要分析的日志文件到待分析文件列表:

如果沒有運行在歸檔模式,那么由于重做日志文件的循環(huán)使用可能導致日志文件被覆蓋而無法獲取到所要尋找的恢復條目。如果運行在歸檔模式,則可以通過查看$ORACLE_HOME\admin\orcl\bdump目錄下的alert_orcl.log里日志文件歸檔的時間和錯誤操作的時間來確定加入哪些歸檔日志文件到待分析的文件列表中去。

注意:執(zhí)行以上過程時logfilename參數(shù)需要寫日志文件的全路徑,否則會報錯。重復以上操作直到把所有需要分析的文件都加到列表中去。這樣就可以啟動進行分析。

3、使用dbms_logmnr里的存儲過程start_logmnr啟動分析;

這樣就可以通過下面的查詢來獲取日志文件的內容了。

4、查詢與dbms_logmnr相關的幾個視圖來獲取日志文件內容;

這樣就可以找出要恢復所需的語句。注意:v$logmnr_contents只對執(zhí)行dbms_logmnr.start_logmnr的會話有效,如果通過其他會話或者使用dbms_logmnr.end_logmnr終止了分析,都將不能訪問v$logmnr_contents的數(shù)據(jù)。如果要使其他會話也能獲取到這些數(shù)據(jù),可以通過另外建表來實現(xiàn),如:

create table undo_sql as select * from v$logmnr_contents。

再對undo_sql進行授權,其他用戶就可以訪問v$logmnr_contents的數(shù)據(jù)了。

5、使用dbms_logmnr里的存儲過程end_logmnr結束分析。

使用完成以后用下面的命令來結束分析活動:exec dbms_logmnr.end_logmnr;

這樣就釋放了分配給logminer的資源(內存和數(shù)據(jù)結構)。

從上面的過程可知,如果是更新的數(shù)據(jù)量比較大,而日志文件比較小,就可能會導致日志文件的切換。如果沒有及時去挖掘日志文件(沒有運行在歸檔模式),那么可能會由于日志文件的循環(huán)使用而導致數(shù)據(jù)不可恢復。如果運行在歸檔模式,也可能由于需要分析的日志文件比較多而時間較長。

四、利用flashback新特性恢復數(shù)據(jù)

Oracle9i 開始提供了閃回查詢(Flashback Query)功能,對于誤刪除或者誤更新并且已經(jīng)commit了的情況提供了簡便快捷的恢復方法;而在Oracle 提供閃回查詢之前,碰到這種情況只能通過備份來進行基于時間點的恢復或者使用logmnr挖掘日志來恢復,無疑這比閃回查詢要麻煩而且費時。

使用這個Flashback Query特性的前提條件:

1. 數(shù)據(jù)庫必須處于Automatic Undo Management 狀態(tài)。

2. 最大可以閃回查詢的時間段由UNDO_RETENTION 初始化參數(shù)(單位為秒)指定

可以通過ALTER SYSTEM SET UNDO_RETENTION = seconds>;來動態(tài)修改參數(shù)值。

▲如何使用Flashback Query來恢復數(shù)據(jù)呢?

1. 通過SQL

使用SELECT 語句的AS OF 來進行閃回查詢,語法如下:

使用AS OF 關鍵字來對表,視圖或者物化視圖進行Flashback Query,如果指定了SCN,那么expr 部分必須是一個數(shù)字,如果指定了TIMESTAMP,那么expr 必須是一個timestamp類型的值。查詢結果將返回在指定的SCN 或者時間點上的數(shù)據(jù)。

下面我們使用scott 方案來作一個實驗。

如果想在update 的子查詢部分使用AS OF,那么該查詢只能返回一條記錄,否則將會報錯。

可以通過添加一個臨時表作為中轉,然后再作更新,如下:

2.通過DBMS_FLASHBACK包來恢復

DBMS_FLASHBACK 包提供了以下幾個函數(shù):

ENABLE_AT_TIME:設置當前SESSION 的閃回查詢時間

ENABLE_AT_SYSTEM_CHANGE_NUMBER:設置當前SESSION 的閃回查詢SCN

GET_SYSTEM_CHANGE_NUMBER:取得當前數(shù)據(jù)庫的SCN

DISABLE:關閉當前SESSION 的閃回查詢

當將一個SESSION 設置為閃回查詢模式之后,后續(xù)的查詢都會基于那個時間點或者SCN 的數(shù)據(jù)庫狀態(tài),如果SESSION 結束,那么即使沒有明確指定DISABLE,閃回查詢也會自動失效。

當SESSION 運行在閃回查詢狀態(tài)時,不允許進行任何DML 和DDL 操作。如果要用DML操作來進行數(shù)據(jù)恢復就必須使用PL/SQL 游標。

▲示例:

通過上面的例子可以看出,只要這個修改的時間不早于sysdate- (UNDO_RETENTION指定的秒數(shù)),就可通過這種方式來恢復數(shù)據(jù)。

對于問題中的批量數(shù)據(jù),可以寫個過程來完成獲取到更改前的數(shù)據(jù):

然后再用這個臨時表里的數(shù)據(jù)來更新TFUNDASSET就可以了。

五、總結

比較以上幾種恢復數(shù)據(jù)的方法的使用過程,我們可以看出:

      ● exp/imp只適合于數(shù)據(jù)變化不大的表的數(shù)據(jù)丟失的情況,即使用這種方法處理后也需要從業(yè)務辦理資料中修正數(shù)據(jù),否則導致數(shù)據(jù)丟失;

      ● 采用基于時間點的不完全恢復可以恢復丟失的數(shù)據(jù),但是需要關關閉數(shù)據(jù)庫,減少系統(tǒng)可用時間,而且也會丟失恢復時間點以后的數(shù)據(jù);

      ● 使用LogMiner可以較好的恢復數(shù)據(jù),但是要求數(shù)據(jù)庫盡可能運行在歸檔模式,否則也可能導致數(shù)據(jù)丟失。好處是不用關閉系統(tǒng),能夠從日志文件中得到所有的數(shù)據(jù)。

      ● 使用Flashback最方便和簡潔,可以直接得到修改前的數(shù)據(jù),但是需要依賴系統(tǒng)設置,并且需要占用大量的回滾表空間。

因此選擇什么樣的方法來恢復數(shù)據(jù),取決于你的系統(tǒng)環(huán)境和具體情況,不能生搬硬套。采用正確的方法才能最大程度的減少數(shù)據(jù)的丟失。

當然,最好是不需要用到這些恢復的辦法。前提是,你必須做好以下的工作:

1、 為不同環(huán)境創(chuàng)建不同的數(shù)據(jù)庫用戶、不同密碼(如果不能用戶不同,一定要密碼不同);

2、 將owner和應用用戶分開,并做適度授權;

3、 在做DML前,先用同樣的條件做查詢,看根據(jù)結果集是否符合預期。

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

您可能感興趣的文章:
  • Oracle數(shù)據(jù)塊損壞之10231內部事件不完全恢復
  • [Oracle] 解析在沒有備份的情況下undo損壞怎么辦
  • ORACLE檢查找出損壞索引(Corrupt Indexes)的方法詳解
  • Oracle數(shù)據(jù)庫的備份與恢復
  • Oracle誤刪除表數(shù)據(jù)后的數(shù)據(jù)恢復詳解
  • oracle冷備份恢復和oracle異機恢復使用方法
  • oracle如何恢復被覆蓋的存儲過程
  • oracle drop table(表)數(shù)據(jù)恢復方法
  • ORACLE 數(shù)據(jù)庫RMAN備份恢復
  • Oracle數(shù)據(jù)庫不同損壞級別的恢復教程

標簽:固原 承德 甘肅 開封 青島 和田 武漢 周口

巨人網(wǎng)絡通訊聲明:本文標題《Oracle數(shù)據(jù)庫數(shù)據(jù)丟失恢復的幾種方法總結》,本文關鍵詞  Oracle,數(shù)據(jù)庫,數(shù)據(jù),丟失,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle數(shù)據(jù)庫數(shù)據(jù)丟失恢復的幾種方法總結》相關的同類信息!
  • 本頁收集關于Oracle數(shù)據(jù)庫數(shù)據(jù)丟失恢復的幾種方法總結的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 雷山县| 维西| 琼中| 郯城县| 西充县| 綦江县| 威信县| 镇原县| 三亚市| 藁城市| 博罗县| 邢台县| 兴安县| 靖远县| 金堂县| 五大连池市| 建始县| 历史| 甘洛县| 启东市| 阿巴嘎旗| 鹤壁市| 乐业县| 称多县| 自治县| 玛纳斯县| 江达县| 赣州市| 尼玛县| 汉寿县| 文成县| 阜平县| 隆安县| 肥城市| 河西区| 大同市| 若尔盖县| 竹北市| 肇源县| 永顺县| 三原县|