校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Oracle誤刪除表數據后的數據恢復詳解

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

熱門標簽:廣東營銷智能外呼系統商家 地圖標注怎么保存 車瑪仕極限運動場所地圖標注 外呼電話系統用卡嗎 七日殺a19.5全地圖標注 高德地圖標注公司名字大全 騰訊地圖標注要費用嗎 電渠外呼系統 N個你智能電銷機器人

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 on
DECLARE r_temp hr.job_history%ROWTYPE;
CURSOR c_temp IS SELECT * FROM hr.job_history;
BEGIN
OPEN c_temp;
dbms_flashback.disable;
LOOP
FETCH 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: 12929941968
old  1: select count(*) from hs_passport as of scn scn
new  1: select count(*) from hs_passport as of scn 12929941968
 COUNT(*)
----------
  861684

SQL> /
Enter value for scn: 12927633776
old  1: select count(*) from hs_passport as of scn scn
new  1: select count(*) from hs_passport as of scn 12927633776
select count(*) from hs_passport as of scn 12927633776
           *
ERROR at line 1:
ORA-01466: unable to read data - table definition has changed

SQL> /
Enter value for scn: 12929928784
old  1: select count(*) from hs_passport as of scn scn
new  1: select count(*) from hs_passport as of scn 12929928784

 COUNT(*)
----------
  825110

SQL> /
Enter value for scn: 12928000000
old  1: select count(*) from hs_passport as of scn scn
new  1: select count(*) from hs_passport as of scn 12928000000
select 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 sysdba
Connected.
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/lsf
Connected.
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 lsf

SQL> set time on
10: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 lsf

10: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 lsf

10: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 selected

10: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 lsf

6 rows selected.

10:20:56 SQL> delete T;

6 rows deleted.

10:21:27 SQL> commit;

Commit complete.

10:21:40 SQL> declare
10:22:29  2 cursor flash_recover is
10:22:43  3 select * from T;
10:22:50  4 t_recode T%rowtype;
10:23:11  5 begin
10: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 loop
10: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 lsf

6 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
----------
  3438420

10: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 lsf

6 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數據庫的刪除方法詳解
  • Oracle刪除數據報ORA 02292錯誤的巧妙解決方法
  • oracle 數據按主鍵刪除慢問題的解決方法
  • Oracle刪除重復的數據,Oracle數據去重復
  • Oracle數據庫中的級聯查詢、級聯刪除、級聯更新操作教程
  • 徹底刪除Oracle數據庫的方法
  • oracle查詢重復數據和刪除重復記錄示例分享
  • oracle數據庫添加或刪除一列的sql語句
  • oracle 批量刪除表數據的幾種方法

標簽:棗莊 長沙 來賓 遼寧 玉樹 贛州 蘇州 大興安嶺

巨人網絡通訊聲明:本文標題《Oracle誤刪除表數據后的數據恢復詳解》,本文關鍵詞  Oracle,誤,刪除,表,數據,后的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle誤刪除表數據后的數據恢復詳解》相關的同類信息!
  • 本頁收集關于Oracle誤刪除表數據后的數據恢復詳解的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    精品国产乱码久久久久久浪潮| 国产亚洲短视频| 国产一区二区三区在线观看精品| 国产精品毛片大码女人| 日韩一区二区三区四区五区六区| 99精品视频在线播放观看| 免费成人在线观看视频| 亚洲精品一二三| 国产午夜精品久久久久久久 | 欧美精品日韩一本| 成人性视频网站| 久久精品国内一区二区三区| 一区二区三区丝袜| 国产偷v国产偷v亚洲高清| 91麻豆精品国产综合久久久久久| av毛片久久久久**hd| 精品一区二区三区在线播放视频 | 蜜桃精品视频在线观看| 亚洲夂夂婷婷色拍ww47| 中文字幕免费不卡在线| 精品国产123| 欧美一级精品在线| 欧美日韩高清在线| 91国在线观看| 色综合久久88色综合天天| 大胆亚洲人体视频| 国产一区二区电影| 久久er99精品| 久久精品国产一区二区| 亚洲成人免费在线观看| 一区二区三区四区在线| 亚洲欧美视频一区| 中文字幕在线播放不卡一区| 欧美国产欧美亚州国产日韩mv天天看完整 | 欧美成人三级电影在线| 欧美精品亚洲一区二区在线播放| 欧美午夜在线一二页| 色婷婷狠狠综合| 色婷婷av一区二区三区大白胸 | 国产剧情一区二区三区| 久久99精品国产91久久来源| 久久国产精品区| 蜜臀99久久精品久久久久久软件| 视频一区二区三区中文字幕| 亚洲一二三区在线观看| 午夜精品在线视频一区| 日本va欧美va精品| 麻豆精品在线播放| 国产真实乱子伦精品视频| 久88久久88久久久| 国内精品久久久久影院薰衣草| 国产尤物一区二区在线| 国产盗摄一区二区| 成人av小说网| 色播五月激情综合网| 欧美伊人精品成人久久综合97 | wwww国产精品欧美| 国产日韩欧美精品一区| 欧美国产欧美综合| 一区二区三区四区精品在线视频| 亚洲电影第三页| 美女在线一区二区| 国产精品乡下勾搭老头1| eeuss鲁片一区二区三区| 欧美亚洲愉拍一区二区| 欧美一二三区在线| 久久久久久久国产精品影院| 国产精品妹子av| 一区二区日韩av| 免费在线观看一区二区三区| 狠狠色丁香婷婷综合| 99re6这里只有精品视频在线观看| 欧美性大战xxxxx久久久| 欧美成人国产一区二区| 国产精品日韩成人| 亚洲国产aⅴ天堂久久| 麻豆精品国产传媒mv男同| 国产老妇另类xxxxx| 色综合久久久久久久| 日韩欧美中文字幕精品| 国产精品久久久久影视| 天天综合天天综合色| 国产寡妇亲子伦一区二区| 欧美午夜精品一区| 久久精品网站免费观看| 亚洲成人一区在线| 国产91精品在线观看| 欧美三级电影网| 日本一区二区三区dvd视频在线| 亚洲一级二级在线| 粉嫩av一区二区三区粉嫩| 欧美色综合网站| 中文久久乱码一区二区| 日韩av午夜在线观看| 成人精品视频一区| 日韩一区二区免费高清| 亚洲同性gay激情无套| 精品一区二区在线免费观看| 欧美性色黄大片| 国产人久久人人人人爽| 日本不卡一区二区三区高清视频| 91亚洲国产成人精品一区二区三 | 日韩精品视频网站| 成人激情综合网站| 欧美大胆人体bbbb| 亚洲一区二区三区四区在线免费观看| 精品一区二区三区蜜桃| 欧美视频在线播放| 成人欧美一区二区三区小说| 国模少妇一区二区三区| 欧美日韩国产片| 专区另类欧美日韩| 国产乱子伦视频一区二区三区 | 欧美电视剧免费观看| 亚洲成人在线观看视频| 色综合久久中文字幕综合网| 久久久精品国产99久久精品芒果 | 亚洲欧美另类小说| 国产成人一级电影| 亚洲精品在线三区| 久久精品国产免费| 欧美日韩午夜在线| 亚洲精品福利视频网站| 99久久综合狠狠综合久久| 国产三级精品在线| 国产一区二区福利视频| 久久伊99综合婷婷久久伊| 精品一区二区三区在线视频| 欧美一区二区三区在线电影| 偷拍日韩校园综合在线| 欧美午夜电影在线播放| 亚洲午夜羞羞片| 欧美色图天堂网| 亚洲精品国产精品乱码不99| 91色在线porny| 一区二区三区中文字幕| 91国产免费看| 亚洲午夜久久久久中文字幕久| 欧美综合视频在线观看| 亚洲一区二区三区四区在线免费观看| 色成年激情久久综合| 亚洲午夜在线视频| 欧美老肥妇做.爰bbww视频| 亚洲6080在线| 日韩一区二区三区四区| 激情国产一区二区| 久久久另类综合| 成av人片一区二区| 亚洲欧洲无码一区二区三区| 99国产欧美久久久精品| 亚洲欧美日韩一区二区| 在线看国产一区| 日韩国产一二三区| 精品国产一区二区在线观看| 国内精品国产成人国产三级粉色 | 91亚洲精品乱码久久久久久蜜桃| 亚洲精品成人a在线观看| 91搞黄在线观看| 日本午夜精品视频在线观看| 精品国产91乱码一区二区三区| 国产激情一区二区三区桃花岛亚洲| 国产欧美日产一区| 91福利资源站| 免费人成网站在线观看欧美高清| 久久一区二区三区国产精品| 成人午夜免费av| 亚洲一区二区三区精品在线| 日韩一二三区视频| 成人激情图片网| 亚洲va韩国va欧美va| 久久久久久久久久久久久久久99 | 久久亚洲一区二区三区四区| 丰满少妇久久久久久久| 亚洲愉拍自拍另类高清精品| 日韩视频在线永久播放| 成人高清视频在线| 五月天网站亚洲| 日本一区二区三区国色天香| 欧美性一二三区| 国产一区二区三区观看| 亚洲自拍偷拍av| 国产亚洲污的网站| 欧美性生活一区| 国产黄色91视频| 丝袜亚洲另类欧美综合| 亚洲国产精品成人综合| 欧美日韩国产高清一区| 成人性生交大片免费看视频在线 | 国产揄拍国内精品对白| 一区二区国产盗摄色噜噜| 日韩欧美黄色影院| 色88888久久久久久影院野外| 久久成人18免费观看| 亚洲精品乱码久久久久久黑人| 精品99999| 欧美日韩电影在线| 91在线精品秘密一区二区| 韩国av一区二区| 午夜精品123| 亚洲女爱视频在线|