MySQL で誤って削除したテーブル データを回復する方法 (必読)

MySQL で誤って削除したテーブル データを回復する方法 (必読)

バックアップがあれば、非常に簡単です。最新のバックアップ データを生成し、mysqlbinlog を使用してバックアップ時点以降のデータを取得し、現在のネットワークに復元するだけです。

バックアップがない場合、面倒なことになり、データの取得コストも非常に高くなります。

バックアップ時点以降のデータを取得するために mysqlbinlog を使用する方法は次のとおりです。

簡単な実験として、mysql テーブル データを削除し、mysqlbinlog を使用して削除したテーブルのデータを取得します。

アプリテーブルの作成時間とデータの挿入時間: 2013-02-04 10:00:00

原則: mysqlbinlog

前提条件: mysql で bin ログが有効になっている

削除をテストする前に:

mysql> テーブルを表示します。
+-----------------------+
| レポート内のテーブル |
+-----------------------+
| アプリ |
| テスト |
+-----------------------+

mysql> now() を選択します。
+---------------------+
| 今() |
+---------------------+
| 2013-02-04 11:45:44 |
+---------------------+
セット内の1行(0.01秒)


mysql> アプリから count(1) を選択します。
+----------+
| カウント(1) |
+----------+
| 10 |
+----------+
セット内の1行(0.01秒)

データの削除を開始します:

mysql> id =1 のアプリから削除します。
クエリは正常、1 行が影響を受けました (0.00 秒)

マイSQL> 
mysql> ID < 6 のアプリから削除します。
クエリは正常、4 行が影響を受けました (0.01 秒)


mysql> アプリから count(1) を選択します。
+----------+
| カウント(1) |
+----------+
| 5 |
+----------+
セット内の 1 行 (0.00 秒)

 

mysql> now() を選択します。
+---------------------+
| 今() |
+---------------------+
| 2013-02-04 12:08:45 |
+---------------------+

データの取得を開始します:

1. bin ログの場所を見つけます。

/app/mysql/ログ

-rw-rw---- 1 mysql mysql 17K 2月4日 11:43 alert.log
-rw-rw---- 1 mysql mysql 1.0K 11月1日 14:52 master-bin.000001
-rw-rw---- 1 mysql mysql 126 12月25日 14:00 master-bin.000002
-rw-rw---- 1 mysql mysql 126 12月25日 14:02 master-bin.000003
-rw-rw---- 1 mysql mysql 126 12月25日 14:02 master-bin.000004
-rw-rw---- 1 mysql mysql 107 12月25日 14:02 master-bin.000005
-rw-rw---- 1 mysql mysql 13K 2月4日 12:02 master-bin.000006

最近変更されたbinログはmaster-bin.000006だけであることがわかります。

(誤って削除したデータが複数の bin ログにまたがる場合は、bin ログを取得するときにデータを 1 つずつ取得する必要があります。)

この期間中に実行されたすべての SQL ステートメントを、復元する SQL ファイルに保存します。

mysqlbinlog --start-date='2013-02-04 10:00:00' --stop-date='2013-02-04 12:08:45' /app/mysql/log/master-bin.000006 >/app/mysql/mysql_restore_20130204.sql

もちろん、現在のネットワーク環境では、この時間はそれほど正確ではない可能性があり、他のトランザクション SQL ステートメントからの干渉がある可能性があります。

一時データベースの作成

データベース for_bak を作成します。

現在のデータベースアプリで誤って削除されたテーブルをエクスポートします

mysqldump -uroot -ppwd my_db アプリ > /app/mysql/app.sql

現在のデータを一時テーブルにインポートします。

mysql -root -ppwd for_bak < /app/mysql/app.sql

/app/mysql/mysql_restore_20130204.sql の内容の一部を見てみましょう: (悪意のある削除ステートメントが確認できます)

タイムスタンプを 1359949544/*!*/ に設定します。
始める
//*!*/;
# 12878 で
#130204 11:45:44 サーバー ID 1 end_log_pos 12975 クエリ thread_id=5 exec_time=974 error_code=0
タイムスタンプを 1359949544/*!*/ に設定します。
ID = 1 のアプリから削除
//*!*/;
# 12975 で
#130204 11:45:44 サーバー ID 1 end_log_pos 13002 Xid = 106
専念 /*!*/;
# 13002 で
#130204 11:45:44 サーバー ID 1 end_log_pos 13077 クエリ thread_id=5 exec_time=1013 error_code=0
タイムスタンプを 1359949544/*!*/ に設定します。
始める
//*!*/;
# 13077 で
#130204 11:45:44 サーバー ID 1 end_log_pos 13175 クエリ thread_id=5 exec_time=1013 error_code=0
タイムスタンプを 1359949544/*!*/ に設定します。
ID < 6 のアプリから削除
//*!*/;
# 13175 で
#130204 11:45:44 サーバー ID 1 end_log_pos 13202 Xid = 107
専念 /*!*/;
区切り文字 ;
# ログファイルの終了

データがいつ削除されたかを確認できます。 特定の時刻は、select from_unixtime(1359949544); を使用して照会することもできます。

幸いなことに、create table app ステートメントと insert ステートメントもこのファイルに含まれています。 削除ステートメントを手動で削除した後、一時データベースのmysqlbinlogから取得したSQLファイルをソースします。

これにより、アプリは削除される前の状態に復元されます。 次に、一時ライブラリ内のデータを既存のネットワーク データにインポートします (これはこの記事の焦点では​​ありません)。

バックアップがない場合、特に binlog ファイルが多く、それぞれが比較的大きい場合は、アプリ テーブルに関連するすべてのデータを取得するのが非常に面倒になる可能性があります。

その場合、アプリの作成から現在までのアプリテーブルに関連する DML 操作の SQL レコードを、mysqlbinlog を使用して 1 つずつ取得し、データを統合して復元するしかありません。

一般的にこのような状況はまれだと思います。面倒ではありますが、復旧不可能ではありません。

MySQL で誤って削除されたテーブル データを回復する方法 (必読) に関する上記の記事は、私が皆さんと共有したいことのすべてです。この記事が皆さんの参考になれば幸いです。また、123WORDPRESS.COM をサポートしていただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL データを誤って削除した場合の簡単な解決策 (MySQL フラッシュバック ツール)
  • MySQLデータベースを誤って削除した後にデータを回復するための手順
  • mysqlテーブルの物理ファイルを誤って削除した場合の解決策
  • 誤って削除されたMySQLのルートユーザーを回復する方法
  • 誤ってibdata1を削除した後にmysqlを回復する方法
  • MySQL が誤って root ユーザーを削除したり、root パスワードを忘れたりした場合の解決策
  • MySQL のデータの偶発的な削除の解決策と kill ステートメントの原則

<<:  Nginx 運用保守ドメイン名検証方法例

>>:  Chrome Dev Tools を使用してページのパフォーマンスを分析する方法 (フロントエンドのパフォーマンス最適化)

推薦する

MySQLカスタム関数の簡単な使用例

この記事では、例を使用して MySQL カスタム関数の使用方法を説明します。ご参考までに、詳細は以下...

Vueのprovideとinjectの使い方と原則を分析する

まず、provide/inject を使用する理由について説明しましょう。祖父コンポーネントと孫コン...

IDEA が Docker を統合してリモート展開を実現するための詳細な手順

1. Dockerサーバーへのリモートアクセスを有効にするdocker が配置されているリモート サ...

MySQL の日付関数と日付変換およびフォーマット関数

MySQL は、膨大なユーザーベースを持つ無料のリレーショナル データベースです。この記事では、My...

CSS3 でテキストマーキーを実装するためのサンプルコード

背景何が起こったかというと、Luzhu は偶然、宇宙で最高の外部スピーカーを備えた携帯電話について知...

自動ロック画面機能を実現するjs

1. 使用シナリオこのような要件があるため、システムが開発されました。ユーザーがデスクトップを離れ...

IE アドレスバーのアイコン表示問題を解決する 3 つの手順

<br />この Web ページ制作スキル チュートリアルは、Web サイトのアイコンを...

Linux でソフトウェア パッケージのバージョンをアップグレードする方法の詳細な説明

Linux環境で、特定のソフトウェア(パッケージ)がインストールされているかどうかを確認したい。 r...

WeChatアプレットがテキストスクロールを実装

この記事の例では、WeChatアプレットでテキストスクロールを実装するための具体的なコードを参考まで...

ウェブページの背景色を制御する CSS コード

誰もが自分の Web ページの背景にふさわしい画像を見つけることに悩むことが多いと思います。これは事...

MySQLでカーソルを宣言する方法

MySQL でカーソルを宣言する方法: 1. 変数とカーソルを宣言する 結果をvarchar(300...

Windows システムでの MySQL 8.0.21 インストール チュートリアル (図とテキスト)

インストールの提案: インストールには .exe を使用せず、圧縮パッケージを使用してください。これ...

Centos7 に mysql と mysqlclient をインストールする際に遭遇する落とし穴の概要

1. MySQL Yumリポジトリを追加するMySQL公式サイト>ダウンロード>MySQ...

mysql data_dirの変更によって発生するエラー問題を解決する

今日は、新しく購入した Alibaba Cloud ECS 環境 (Ubuntu 16.04 LTS...

HTMLとCSSを使用して、自分だけの暖かい男「Dabai」を作成します

最終結果はこんな感じです、かわいいでしょう… PS: HTML と CSS の知識があればベストです...