ApexSQL Recoverを使用する理由とは
すべての DB管理者 は、失われたデータを回復するという課題に一度は直面したことがあるでしょう。
DELETE 、TRUNCATE TABLE 、DROP TABLES 、データベースの破損、さらには WHERE 句を使用しない非常に一般的な UPDATE など、データが失われる可能性のあるさまざまな方法があります。
もちろん、これらのトラブルが発生したときに、バックアップやデータベースのスナップショットなど、大惨事から回復するさまざまなテクニックがあることは誰もが知っています。
しかし、マーフィーのルールがあり、何も計画通りにいかない場合もあります。
さらに不幸なことに、バックアップがとれていなかった、ということがあるかもしれません。ジョブが失敗したのに気付かなかったのかもしれません。最初からバックアップ計画に追加されていなかった新しいデータベースかもしれません。
このようなピンチになってもパニックにならないでください
ApexSQL Recoverを使用すると、データベースの完全バックアップまたは差分バックアップがなく、トランザクション ログ バックアップもない場合でも、可能な限りSQL データベース レコードを回復できます。
ApexSQL Recover の仕組みを理解するために、テーブルデータが削除されたときに何が起こるかを説明します。
テーブル データはデータ ページに保存されます。テーブル レコードを削除すると、そのレコードはデータ ページからすぐには削除されませんが、新しいレコードによって上書きされるようにマークされます。このようなレコードは表示されなくなりますが、ApexSQL Recover はそれらのレコードを読み取り、元に戻すスクリプトを作成できます。
ApexSQL Recover は次の機能を提供します。
- DELETE 操作からのデータ回復
削除操作はトランザクション ログに完全に記録されますが、データ ファイルからすぐに削除されるとは限りません。したがって、ApexSQL Recover は、ログを読み取るか、データページから抽出するかの両方によってこのデータをサルベージします - INSERT および UPDATE 操作からのデータ回復
データベースが完全復旧モデルの場合、実行されたすべての INSERT および UPDATE 情報に関する情報は、トランザクション ログ ファイルに無期限に、またはログ ファイルが手動で切り捨てられるまで保存されます。つまり、ApexQL Recover をフォレンジックに使用して、INSERT または UPDATE の変更をロールバックし、データを元の状態に戻すことができます。 - TRUNCATE 操作からのデータ回復
SQL Server で TRUNCATE TABLE ステートメントが実行されると、データを含むページはすぐに割り当てが解除されます。これは基本的に、再利用のマークが付けられていることを意味します。SQL Server は、TRUNCATE TABLE ステートメントをオンライン トランザクション ログに完全に記録しますが、ページ割り当てのみを記録することで効率的に記録するため、TRUNCATE TABLE が発生した後にトランザクション ログを使用してデータを抽出することが困難になります。このため、ApexSQL Recoverがこのデータを回復するために使用する主な手法は、データファイル内の割り当て解除されたページを見つけて、データがまだ利用可能かどうかを確認することです。 - DROP TABLE 操作からのデータ回復
ApexSQL Recover は、削除されたテーブルのスキーマとデータの両方を回復できます。このオプションを選択すると、ApexSQL Recover は構造のみ、データのみ、またはその両方をリカバリすることを提案します。truncate 操作と同様に、drop table 操作も効率的にログに記録されます。テーブル構造はトランザクション ログから取得できますが、データはデータ ファイルから回復する必要があります。 - 削除されたBLOBの抽出
バイナリ ラージ オブジェクト (BLOB) は、通常のデータと同じ方法で SQL Server に保存されません。オブジェクトのサイズにより、この種類のデータは必然的に複数のページを保存する必要があるためです。これは、行オーバーフロー データ (varbinary、nvarchar、sqvariant、varchar 型) または LOB データ (text、ntext、または image 型) のいずれかとして使用できます。このようなオブジェクトが失われた場合、トランザクション ログでは見つからないため、ApexSQL Recover はこのタイプのデータをデータ ファイルから抽出します
このように、ApexSQL Recover では、回復時間を短縮するために、データの損失方法に応じてさまざまなオプションが提供されます。
データがどのように失われたかわからない場合、または選択したオプションがうまくいかない場合は、すべてのオプションを試してみてください。これらのオプションはデータの回復に異なる方法を使用するため、オプションが異なると成功率が低かったり高かったりする可能性があります。リカバリを最大限に成功させるには、できるだけ多くの追加のデータ ソースを提供する必要があります。
回復の成功率は、次のようなさまざまな要因によって異なります。
- データベースの復旧モデル
- データが失われたとき
- インシデント発生後どれくらい早く回復を試みるか
- 以前のバックアップ、ログ バックアップ、切り離されたデータ ファイルなど、利用可能な追加のデータ ソース
このページにたどりついた、ピンチのDB管理者がすぐにやらないといけないこと
時間が経つにつれて、レコードが上書きされる可能性が高くなります。削除後にトランザクションが発生すると、レコードが上書きされ、永久に失われる可能性が高くなります。
したがって、データベースの MDF ファイルと LDF ファイルのコピーをすぐに作成してください。
削除された(上書き対象としてマークされた)レコードはバックアップに含まれないため、データベースの完全バックアップは役に立たないことに注意してください。
次に、ApexSQL Recoverの評価版を入手して、復旧を試してみることをお勧めします。