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.原表記録
そして変更を提出します。
削除前のSCNが一番いいと確実に知っていれば、知らなかったら、フラッシュバッククエリの試みができます。
4.データを復元する
データベース操作を行います。deleteの後ろには必ずwhereを追加してください。今日はたまたまネットでoracleの誤って削除したデータの回復についての情報を見ました。確かに使いやすいと思いました。私のテストについてご報告します。
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にこの時点のすべてのデータを見つけた以上、どのように操作してもいいです。
ここで皆さんに分かち合います。
一時手が安いので、生産上のデータが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にこの時点のすべてのデータを見つけた以上、どのように操作してもいいです。
ここで皆さんに分かち合います。