oracle誤削除データ復元方法のまとめ


もしユーザーがデータを誤魔化し/更新した後、ユーザーとして直接的な方法がなくて回復するなら、DBAを助けてデータベースを回復しなければならない。Oracle 9 iに着いたら、この難局は改善された。Or(www.jb 51.net)acle 9 iは新しい技術手段を提供しています。フラッシュクエリを利用して、ユーザーが誤操作前のデータを適時に取得し、エラーに対して相応の回復措置を行うことができます。これらはすべてDBAが関与する必要がありません。
一時手が安いので、生産上のデータがdeleteに落ちました。
delete文を使って、すぐにcomitに返しました。
次の二つの文:
ALTER TABLE table name ENABLE row movement;
flashback table table to timestamp to utimestamp('2012-09-13:00'、'yyy-mm-dd hh 24:mi:ss')
たしか2時半ごろ運行していたdelete-comitです。
具体的な実行フローは以下のいくつかの例図から理解できます。
1.原表記録

 $ sqlplus eygle/eygle
SQL*Plus: Release 10.1.0.2.0 - Production on Wed Mar 30 08:52:04 2005
Copyright (c) 1982, 2004, Oracle.  All rights reserved.
Connected to:
Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 - 64bit Production
With the Partitioning, OLAP and Data Mining options
SQL>select count(*) from t1;
  COUNT(*)
----------
    9318
2.すべてのレコードを誤って削除します。
そして変更を提出します。

SQL>delete from t1;
9318 rows deleted.
SQL>commit;
Commit complete.
SQL>select count(*) from t1;
  COUNT(*)
----------
     0
3.現在のSCNを取得する
削除前のSCNが一番いいと確実に知っていれば、知らなかったら、フラッシュバッククエリの試みができます。

SQL>select dbms_flashback.get_system_change_number from dual;
GET_SYSTEM_CHANGE_NUMBER
------------------------
         10671006
SQL>select count(*) from t1 as of scn 10671000;
  COUNT(*)
----------
     0
SQL>select count(*) from t1 as of scn 10670000;
  COUNT(*)
----------
    9318
私たちはSCN=1070000にデータがあるのを見ました。
4.データを復元する

SQL>insert into t1 select * from t1 as of scn 10670000;
9318 rows created.
SQL>commit;
Commit complete.
SQL>select count(*) from t1;
  COUNT(*)
----------
    9318
他のネット友達用の教程
データベース操作を行います。deleteの後ろには必ずwhereを追加してください。今日はたまたまネットでoracleの誤って削除したデータの回復についての情報を見ました。確かに使いやすいと思いました。私のテストについてご報告します。

 1. select * from t_viradsl2 t     //  t_viradsl2      ,        
 2. delete t_viradsl2           //  t_viradsl2      ,      
 3. select * from t_viradsl2 t     //   。
 4. insert into t_viradsl2 select * from t_viradsl2 as of timestamp to_Date('2011-01-19 15:28:00', 'yyyy-mm-dd hh24:mi:ss')       //           
 5. select * from t_viradsl2 t     //        。
次の第四ステップを分析します。この文に注意してください。
select*from t_viradsl 2 as of timestamp to_Date('2011-01-19 15:28:00'、'yyy-mm-dd hh 24:mi:ss')は、どういう意味ですか?t_を見つけます。Viradsl 2は2011-01-19 15:28にこの時点のすべてのデータを見つけた以上、どのように操作してもいいです。
ここで皆さんに分かち合います。