亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Oracle > 正文

Oracle誤刪除表數據后的數據恢復詳解

2024-08-29 13:58:42
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Oracle誤刪除表數據后的數據恢復詳解,需要的朋友可以參考下
 

Oracle誤刪除表數據后的恢復詳解
 
測試環境:
SYSTEM:IBM AIX 5L                         Oracle Version:10gR2
 

1. undo_retention參數的查詢與修改

使用show parameter undo命令查看當前的數據庫參數undo_retention設置。
顯示如下:
SQL> show parameter undo

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     900
undo_tablespace                      string      UNDOTBS2
undo_retention(保持力),900單位是秒,即15分鐘。
修改默認的undo_retention參數設置:
SQL> ALTER SYSTEM SET undo_retention=10800 SCOPE=BOTH;

System altered.

SQL> show parameter undo

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
undo_management                      string      AUTO
undo_retention                       integer     10800
undo_tablespace                      string      UNDOTBS2
undo_retention 10800,單位秒,即3小時。

2. oracle誤刪除表數據后的的快速恢復功能方法

2.1 方法一
通過oracle提供的回閃功能

exec dbms_flashback.enable_at_time(to_date('2011-04-15 08:21:00','yyyy-mm-dd hh24:mi:ss'));set serveroutput onDECLARE r_temp hr.job_history%ROWTYPE;CURSOR c_temp IS SELECT * FROM hr.job_history;BEGINOPEN c_temp;dbms_flashback.disable;LOOPFETCH c_temp INTO r_temp;EXIT WHEN c_temp%NOTFOUND;insert into hr.job_history(EMPLOYEE_ID,JOB_ID,START_DATE,END_DATE) values (r_temp.EMPLOYEE_ID,r_temp.JOB_ID,r_temp.START_DATE,r_temp.END_DATE);commit;END LOOP;CLOSE c_temp;END;

這種辦法可以將刪除的數據恢復到對應的表中,首先要保證該用戶有執行dbms_flashback包的權限。

2.2 方法二
insert into hr.job_history
select * from hr.job_history as of timestamp to_timestamp('2011-04-15 08:20:00', 'yyyy-mm-dd hh24:mi:ss');
這種方法簡單,容易掌握,功能和上面的一樣,此處的時間為你誤操作之前的時間,最好是離誤操作比較近的,因為oracle保存在回滾保持段里的數據時間有一定的時間限制,這個限制由undo_retention 這個參數值決定。

查看FIRST_CHANGE#,NEXT_CHANGE#,FIRST_TIME
SQL> set pagesize 9999
SQL> col fscn for 999999999
SQL> col nscn for 999999999
SQL> select name,FIRST_CHANGE# fscn,NEXT_CHANGE# nscn,FIRST_TIME from v$archived_log;

當前的SCN為:
SQL> select dbms_flashback.get_system_change_number fscn from dual;
      FSCN
----------
   3435958

使用應用用戶嘗試閃回
SQL> connect username/password
Connected.

現有數據:
SQL> select count(*) from hs_passport;
  COUNT(*)
----------
    851998
創建恢復表:
SQL> create table hs_passport_recov as select * from hs_passport where 1=0;

Table created.

選擇SCN向前恢復:
SQL> select count(*) from hs_passport as of scn 12929970422;
  COUNT(*)
----------
    861686

嘗試多個SCN,獲取最佳值(如果能得知具體時間,那么可以獲得準確的數據閃回)

SQL> select count(*) from hs_passport as of scn &scn;Enter value for scn: 12929941968old  1: select count(*) from hs_passport as of scn &scnnew  1: select count(*) from hs_passport as of scn 12929941968 COUNT(*)----------  861684SQL> /Enter value for scn: 12927633776old  1: select count(*) from hs_passport as of scn &scnnew  1: select count(*) from hs_passport as of scn 12927633776select count(*) from hs_passport as of scn 12927633776           *ERROR at line 1:ORA-01466: unable to read data - table definition has changedSQL> /Enter value for scn: 12929928784old  1: select count(*) from hs_passport as of scn &scnnew  1: select count(*) from hs_passport as of scn 12929928784 COUNT(*)----------  825110SQL> /Enter value for scn: 12928000000old  1: select count(*) from hs_passport as of scn &scnnew  1: select count(*) from hs_passport as of scn 12928000000select count(*) from hs_passport as of scn 12928000000           *ERROR at line 1:ORA-01466: unable to read data - table definition has changed

最后選擇恢復到SCN為12929941968的時間點
SQL> insert into hs_passport_recov select * from hs_passport as of scn 12929941968;

861684 rows created.

SQL> commit;

Commit complete.

數據恢復簡單例子
在過去,如果用戶誤刪/更新了數據后,作為用戶并沒有什么直接的方法來進行恢復,他們必須求助DBA來對數據庫進行恢復,到了Oracle9i,這一難堪的局面有所改善。Oracle 9i中提供了一項新的技術手段--閃回查詢,用戶使用閃回查詢可以及時取得誤操作前的數據,并可以針對錯誤進行相應的恢復措施,而這一切都無需DBA干預。

3. 下面我們通過一個例子來具體說明閃回查詢的用法

示例
3.1 使用閃回查詢前必須確定下面兩個參數:
UNDO_MANAGEMENT = AUTO
undo_retention = 10800; 
這個時間可以隨便設,它表示在系統中保留提交了的UNDO信息的時間,10800就是保留3小時,即180分鐘。
3.2 使用閃回查詢

SQL> conn /as sysdbaConnected.SQL> drop user lsf cascade;User dropped.SQL> create user lsf identified by lsf;User created.SQL> grant connect,resource to lsf;Grant succeeded.SQL> grant execute on dbms_flashback to lsf;Grant succeeded.SQL> conn lsf/lsfConnected.SQL> create table T(id int, name varchar2(20));Table created.SQL> insert into T values(1,'lsf');1 row created.SQL> insert into T values(2,'lsf');1 row created.SQL> insert into T values(3,'lsf');1 row created.SQL> commit;Commit complete.SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     1 lsf     2 lsf     3 lsfSQL> set time on10:12:50 SQL> delete from T where id=1;1 row deleted.10:13:02 SQL> commit;Commit complete.10:13:10 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     2 lsf     3 lsf10:13:18 SQL> execute DBMS_FLASHBACK.ENABLE_AT_TIME(to_date('2011-04-15 10:12:50','YYYY-MM-DD HH24:MI:SS'));PL/SQL procedure successfully completed.10:13:50 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     1 lsf     2 lsf     3 lsf10:13:57 SQL> execute DBMS_FLASHBACK.DISABLE;PL/SQL procedure successfully completed.10:15:48 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     2 lsf     3 lsf

3.3 使用閃回查詢恢復數據

10:16:59 SQL> truncate table T;Table truncated.10:18:15 SQL> select * from T;no rows selected10:18:22 SQL> insert into T values(1,'lsf');1 row created.10:19:42 SQL> insert into T values(2,'lsf');1 row created.10:19:48 SQL> insert into T values(3,'lsf');1 row created.10:19:55 SQL> insert into T values(4,'lsf');1 row created.10:20:07 SQL> insert into T values(5,'lsf');1 row created.10:20:15 SQL> insert into T values(6,'lsf');1 row created.10:20:21 SQL> commit;Commit complete.10:20:26 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     1 lsf     2 lsf     3 lsf     4 lsf     5 lsf     6 lsf6 rows selected.10:20:56 SQL> delete T;6 rows deleted.10:21:27 SQL> commit;Commit complete.10:21:40 SQL> declare10:22:29  2 cursor flash_recover is10:22:43  3 select * from T;10:22:50  4 t_recode T%rowtype;10:23:11  5 begin10:23:14  6 DBMS_FLASHBACK.ENABLE_AT_TIME(to_date('2011-04-15 10:20:56','YYYY-MM-DD HH24:MI:SS'));10:24:22  7 open flash_recover;10:24:39  8 DBMS_FLASHBACK.DISABLE;10:24:59  9 loop10:25:05 10 FETCH flash_recover into t_recode;10:25:24 11 EXIT WHEN flash_recover%NOTFOUND;10:25:45 12 insert into T values(t_recode.id,t_recode.name);10:26:35 13 end loop;10:26:39 14 CLOSE FLASH_RECOVER;10:26:50 15 commit;10:26:56 16 end;10:26:58 17 /PL/SQL procedure successfully completed.10:27:00 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     1 lsf     2 lsf     3 lsf     4 lsf     5 lsf     6 lsf6 rows selected.

我們可以已經恢復了所有的6條紀錄,但是由于閃回查詢的局限性,有可能不能恢復所有的6條記錄,原因就在下面。

4. 局限性
4.1 閃回查詢是基于SCN的,雖然我們執行的是:
DBMS_FLASHBACK.ENABLE_AT_TIME(to_date('2011-04-15 10:20:56','YYYY-MM-DD HH24:MI:SS'));
但Oracle并不會精確的這個時間點,而是ROUND DOWN到最近的一次SCN,然后從這個SCN開始進行恢復。而Oracle 9i是每五分鐘記錄一次SCN的,并將SCN和對應時間的映射做個紀錄。 
因此如果使用DBMS_FLASHBACK.ENABLE_AT_TIME來進行恢復,為了避免恢復失敗,我們可以先等5分鐘,然后再進行恢復。
使用DBMS_FLASHBACK.ENABLE_AT_TIME進行恢復還有一個缺點,那就是在Oracle 9i中SCN和對應時間的映射信息只會保留5天,因此我們無法通過DBMS_FLASHBACK.ENABLE_AT_TIME來恢復5天前的數據。如果你想使用閃回查詢來恢復5天前的數據,你必須自己來確定需要恢復的SCN,然后使用DBMS_FLASHBACK.ENABLE_AT_SYSTEM_CHANGE_NUMBER(SCN_NUMBER); 來定位你的恢復時間點,下面是使用方法:

10:27:27 SQL> VARIABLE SCN_SAVE NUMBER;10:32:47 SQL> EXECUTE :SCN_SAVE := DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER;PL/SQL procedure successfully completed.10:33:24 SQL> print SCN_SAVE; SCN_SAVE----------  343842010:33:41 SQL> execute DBMS_FLASHBACK.ENABLE_AT_SYSTEM_CHANGE_NUMBER(:SCN_SAVE);PL/SQL procedure successfully completed.10:34:31 SQL> select * from T;    ID NAME---------- ------------------------------------------------------------     1 lsf     2 lsf     3 lsf     4 lsf     5 lsf     6 lsf6 rows selected.

另外,在使用DBMS_FLASHBACK.ENABLE_AT_TIME前,你必須設定你的NLS_DATE_FORMAT的精確程度,Oracle默認的是精確到天,如果你不設定,像上面的例子你不會得到預期結果。
4.2 如果你使用sysdate和DBMS_FLASHBACK.GET_SYSTEM_CHANGE_NUMBER來獲取時間點或者SCN值,你必須注意它們取得都是當前的時間點和SCN值。
4.3 你只能在事務開始時進入閃回查詢模式,如果之前有DML操作,則必須COMMIT。
4.4 閃回查詢無法恢復到表結構改變之前,因為閃回查詢使用的當前的數據字典。



注:相關教程知識閱讀請移步到oracle教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲国产视频小说| 国产精品日韩一区| 日韩av123| 成人激情电影一区二区| 亚洲精品成人久久电影| 日韩女优人人人人射在线视频| 亚洲男人天堂视频| 91大神在线播放精品| 亚洲经典中文字幕| 亚洲欧美色婷婷| 在线观看日韩欧美| 欧美电影免费看| 亚洲久久久久久久久久| 国产精品h片在线播放| 久久亚洲私人国产精品va| 色天天综合狠狠色| 92国产精品久久久久首页| 国产69精品99久久久久久宅男| 日韩欧中文字幕| 国产精品一区二区三区在线播放| 精品国产一区二区三区久久久狼| xvideos亚洲人网站| 欧美重口另类videos人妖| 欧美黄色性视频| 成人精品一区二区三区电影黑人| 少妇av一区二区三区| 亚洲男人天堂九九视频| 日韩欧美精品网址| 成人写真视频福利网| 国产精品黄色影片导航在线观看| 在线成人免费网站| 亚洲综合在线中文字幕| 国产在线观看精品一区二区三区| 日韩av电影免费观看高清| 日韩欧美在线播放| 性欧美亚洲xxxx乳在线观看| 色狠狠av一区二区三区香蕉蜜桃| 亚洲综合自拍一区| 九九热r在线视频精品| 性色av一区二区三区红粉影视| 久久在线视频在线| 欧美性在线观看| 欧美激情视频一区| 国产精品成人在线| 国产精品流白浆视频| 久久五月天综合| 日韩中文字幕在线观看| 国产精品扒开腿做| 亚洲欧洲午夜一线一品| 一区国产精品视频| 亚洲精品电影在线观看| 国产成人91久久精品| 国产精品亚洲片夜色在线| 日韩美女在线观看| 国产91在线视频| 久久久亚洲精品视频| 日本高清久久天堂| 久久伊人91精品综合网站| 午夜精品免费视频| 欧美亚洲激情在线| 成人网址在线观看| 欧美日韩国产在线| 欧美成年人视频网站| 欧美日韩精品中文字幕| 成人激情视频在线| 国产精品扒开腿做爽爽爽的视频| 国产一区私人高清影院| 久久精品电影网| 亚洲成人精品久久| 国产精品视频成人| 日韩国产激情在线| 国产精品99蜜臀久久不卡二区| 黑人巨大精品欧美一区二区| 国产精品福利久久久| 日韩欧美有码在线| 中文字幕日本精品| 亚洲国产小视频在线观看| 亚洲精品一区中文字幕乱码| 91sao在线观看国产| 日韩中文娱乐网| 日av在线播放中文不卡| 国产精品视频网站| 国产精品444| 国产国语刺激对白av不卡| 成人国产在线视频| 欧美激情手机在线视频| 日韩福利视频在线观看| 久久久国产精品x99av| 色婷婷综合久久久久中文字幕1| 国产精品18久久久久久首页狼| 欧美激情一区二区三区久久久| 亚洲国产成人91精品| 欧美成人免费在线视频| 国产欧美va欧美va香蕉在| 亚洲新声在线观看| 中文字幕欧美在线| 亚洲天堂影视av| 97免费视频在线| 欧美激情在线观看视频| www.久久草.com| 亚洲国产精品推荐| 欧美激情第6页| 国模叶桐国产精品一区| 91精品国产99久久久久久| 日韩中文娱乐网| 中文字幕亚洲情99在线| 亚洲国产日韩欧美在线图片| 日本中文字幕久久看| 亚洲免费一在线| 国产精品女人久久久久久| 亚洲系列中文字幕| 国产精品爽爽ⅴa在线观看| 久久久亚洲福利精品午夜| 久久综合免费视频影院| 成人a免费视频| 久久视频在线直播| 91夜夜未满十八勿入爽爽影院| 日本高清久久天堂| 性金发美女69hd大尺寸| 成人精品一区二区三区电影黑人| 亚洲男人av在线| 午夜精品一区二区三区在线视频| 日韩欧美在线免费观看| 国产精品老女人精品视频| 成人信息集中地欧美| 久久五月天色综合| 国产精品视频中文字幕91| 久久久av免费| 国产mv免费观看入口亚洲| 久久综合国产精品台湾中文娱乐网| 欧美黄色片视频| 国产欧美精品va在线观看| 亚洲精品色婷婷福利天堂| 欧美日韩另类字幕中文| 亚洲色图美腿丝袜| 亚洲最大的av网站| 亚洲三级 欧美三级| 热99久久精品| 中文字幕亚洲一区在线观看| 欧美日韩aaaa| 国产精品2018| 成人日韩av在线| 欧美电影在线观看完整版| 久久中国妇女中文字幕| 久久国产精品视频| 性色av香蕉一区二区| 久久久噜久噜久久综合| 亚洲最大av网| 欧美中文在线字幕| 亚洲国产精品va在线看黑人动漫| 日韩欧美高清视频| 精品五月天久久| 日产精品久久久一区二区福利| 91国自产精品中文字幕亚洲| 亚洲午夜激情免费视频| 亚州国产精品久久久| 国产精品成人播放| 丝袜情趣国产精品| 亚洲男人第一av网站| 日本成熟性欧美| 91网站免费观看| 欧美成人免费视频| 国产成人精品久久二区二区91| 日韩电影中文字幕av|