>  기사  >  데이터 베이스  >  mysql에서 삭제된 테이블을 복원하는 방법은 무엇입니까? 실수로 삭제된 테이블에서 데이터를 검색하는 MySQL 방법

mysql에서 삭제된 테이블을 복원하는 방법은 무엇입니까? 실수로 삭제된 테이블에서 데이터를 검색하는 MySQL 방법

黄舟
黄舟원래의
2017-03-28 13:28:3119419검색

아래 편집기에서 mysql 실수로 삭제된 테이블에서 데이터를 검색하는 방법(반드시 읽어야 함)에 대한 기사를 제공합니다. 편집자님이 꽤 좋다고 생각하셔서 지금 공유하고 모두에게 참고용으로 드리고자 합니다. 편집자를 따라가서 살펴보겠습니다.

mysql에서 삭제된 테이블을 복원하는 방법은 무엇입니까? 실수로 삭제된 테이블에서 데이터를 검색하는 MySQL 방법

백업이 있는 경우 매우 간단합니다. 최신 백업 데이터만 생성한 후, 백업 시점 이후의 데이터를 mysqlbinlog를 사용하여 검색하면 됩니다. 그런 다음 복원하십시오.

백업이 없으면 번거로울 수 있고, 데이터를 가져오는 데 드는 비용도 매우 높습니다.

다음은 백업 후 데이터를 가져오는 mysqlbinlog에 대한 소개입니다. 방법:

간단한 실험을 해보고, mysql 테이블 데이터를 삭제한 후, 방금 삭제한 테이블의 데이터를 mysqlbinlog를 이용하여 검색한다. .

앱 테이블 생성 시간 및 데이터 삽입

원리: mysqlbinlog

전제: mysql에 bin 로그가 활성화되어 있음

테스트 전 삭제:

mysql> show tables;
+-----------------------+
| Tables_in_report_sina |
+-----------------------+
| app     |
| test     |
+-----------------------+

mysql> select now();
+---------------------+
| now()    |
+---------------------+
| 2013-02-04 11:45:44 |
+---------------------+
1 row in set (0.01 sec)


mysql> select count(1) from app;
+----------+
| count(1) |
+----------+
|  10 |
+----------+
1 row in set (0.01 sec)

데이터 삭제 시작:

mysql> delete from app where id =1;
Query OK, 1 row affected (0.00 sec)

mysql> 
mysql> delete from app where id <6;
Query OK, 4 rows affected (0.01 sec)


mysql> select count(1) from app;
+----------+
| count(1) |
+----------+
|  5 |
+----------+
1 row in set (0.00 sec)

 

mysql> select now();
+---------------------+
| now()    |
+---------------------+
| 2013-02-04 12:08:45 |
+---------------------+

데이터 검색 시작:

1. bin 로그 위치 찾기:

/app/mysql/log

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

최근 수정된 bin 로그는 master-bin.000006

뿐입니다. (실수로 여러 개의 bin 로그에 걸쳐 삭제한 경우 데이터 검색 시 bin 로그를 하나씩 검색해야 합니다.)

이 기간 동안 실행된 모든 sql 문을 sql 파일에 저장하여 중간에 복원하세요.

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

물론 현재 네트워크 환경에서는 이번 시간이 그다지 정확하지 않을 수 있으며, 다른 거래 SQL문의 간섭도 있을 수 있습니다.

임시 데이터베이스 만들기

create database for_bak;

현재 데이터베이스에서 실수로 삭제한 테이블 앱 내보내기

mysqldump -uroot -ppwd my_db app > /app/mysql/app.sql

현재 데이터를 임시 테이블로 가져옵니다.

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

/app/mysql/mysql_restore_20130204의 내용 중 일부를 살펴보겠습니다. sql: (알겠습니다 사악한 삭제문을 보세요)

SET TIMESTAMP=1359949544/*!*/;
BEGIN
/*!*/;
# at 12878
#130204 11:45:44 server id 1 end_log_pos 12975 Query thread_id=5 exec_time=974 error_code=0
SET TIMESTAMP=1359949544/*!*/;
delete from app where id =1
/*!*/;
# at 12975
#130204 11:45:44 server id 1 end_log_pos 13002 Xid = 106
COMMIT/*!*/;
# at 13002
#130204 11:45:44 server id 1 end_log_pos 13077 Query thread_id=5 exec_time=1013 error_code=0
SET TIMESTAMP=1359949544/*!*/;
BEGIN
/*!*/;
# at 13077
#130204 11:45:44 server id 1 end_log_pos 13175 Query thread_id=5 exec_time=1013 error_code=0
SET TIMESTAMP=1359949544/*!*/;
delete from app where id <6
/*!*/;
# at 13175
#130204 11:45:44 server id 1 end_log_pos 13202 Xid = 107
COMMIT/*!*/;
DELIMITER ;
# End of log file

어느 시점에 데이터가 삭제되었는지 알 수 있습니다. 또한 select from_unixtime(1359949544);를 사용하여 특정 시간을 쿼리할 수도 있습니다

만족스러운 점은 create table app 문과 insert 문도 이 파일에 있다는 것입니다. 삭제 문을 수동으로 제거한 후 mysqlbinlog가 검색한 SQL 파일

을 임시 라이브러리에 소싱하여 앱을 삭제되기 전의

상태로 복원합니다. 그런 다음 임시 데이터베이스의 데이터를 라이브 네트워크 데이터로 가져옵니다(이 문서의 초점은 아닙니다).

백업이 없으면 앱 테이블과 관련된 모든 데이터를 검색하는 것이 매우 번거로울 수 있습니다. 특히 binlog 파일이 많고 각 파일의 크기가 상대적으로 큽니다.

이 경우 mysqlbinlog만 이용하면 앱 생성부터 현재까지 앱 테이블과 관련된 DML 작업의 SQL 레코드를 하나씩 조회한 후 데이터를 통합 및 복원할 수 있다.

대체로 이런 상황은 비교적 드물다고 생각합니다. 번거롭기는 하지만 회복이 불가능하지는 않습니다.

위 내용은 mysql에서 삭제된 테이블을 복원하는 방법은 무엇입니까? 실수로 삭제된 테이블에서 데이터를 검색하는 MySQL 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.