집 >데이터 베이스 >MySQL 튜토리얼 >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='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문의 간섭도 있을 수 있습니다.
임시 데이터베이스 만들기
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!