MySQL은 다양한 유형의 애플리케이션에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 데이터의 양이 계속 증가함에 따라 실수로 데이터를 삭제하는 문제가 점점 더 일반화되었습니다. 이번 글에서는 다양한 방법을 통해 MySQL에서 실수로 삭제된 데이터를 복구하는 방법을 소개하겠습니다.
MySQL 서버가 InnoDB 스토리지 엔진을 사용하는 경우 롤백(ROLLBACK) 작업을 사용하여 실수로 삭제된 데이터를 복구할 수 있습니다. 롤백 작업은 데이터베이스 테이블 상태를 이전 시점으로 롤백하여 수행할 수 있습니다. 실수로 데이터를 삭제하기 전에 다음 명령을 사용하여 트랜잭션을 열 수 있습니다:
START TRANSACTION;
그런 다음 실수로 삭제를 수행하기 전에 현재 테이블의 상태를 저장할 수 있습니다:
SAVEPOINT mysavepoint;
실수로 데이터를 삭제한 경우 다음 명령을 사용하여 테이블 상태를 저장 지점으로 롤백할 수 있습니다.
ROLLBACK TO SAVEPOINT mysavepoint; 이 방법으로 데이터를 복원할 수 있습니다.
바이너리 로그 파일 사용MySQL 서버에서 바이너리 로그 기능을 활성화하기 전에 my.cnf 파일에서 구성해야 합니다. [mysqld] 섹션에 다음 줄을 추가합니다.
log-bin=mysql-bin
binlog-format=ROW
그런 다음 구성이 적용되도록 MySQL 서버를 다시 시작합니다.
바이너리 로깅이 활성화되면 MySQL의 자체 도구인 mysqlbinlog를 사용하여 이러한 로그 파일을 구문 분석하고 실수로 삭제된 데이터를 찾을 수 있습니다. 다음 명령을 실행합니다:
mysqlbinlog binlog.000001 --start-position=1200000 > /tmp/mysql-binlog-output.txt
여기서 binlog.000001은 바이너리 로그 파일의 이름이고 --start- 위치는 구문 분석을 시작하는 위치를 지정하고, > /tmp/mysql-binlog-output.txt는 /tmp/mysql-binlog-output.txt 파일에 대한 출력을 지정합니다.
출력 파일에는 모든 쓰기 작업이 포함됩니다. 필터링 및 검색을 통해 실수로 삭제된 데이터를 찾아 데이터베이스에 다시 삽입할 수 있습니다.
백업 파일 사용백업 파일에서 데이터를 복구하는 구체적인 단계는 백업 도구 및 버전에 따라 다릅니다. 그러나 일반적으로 다음 단계로 나눌 수 있습니다.
MySQL 서버를 중지합니다.결론
실수로 데이터를 삭제하는 것은 MySQL 데이터베이스 관리에서 흔히 발생하는 문제입니다. 많은 경우 실수로 데이터를 삭제하면 심각한 결과를 초래할 수 있습니다. 따라서 데이터 복구는 매우 중요합니다. 이 문서에서는 실수로 삭제된 데이터를 복구하는 몇 가지 일반적인 방법을 소개했습니다. 이러한 방법이 MySQL 데이터베이스를 더 잘 관리하는 데 도움이 되기를 바랍니다.
위 내용은 mysql 복구 실수로 삭제된 데이터 복구의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!