데이터베이스의 데이터를 일괄 삭제하는 Mysql 방법: LIMIT 매개변수를 통해 일괄 삭제, 구문은 [DELETE FROM syslogs WHERE status=1 ORDER BY statusid LIMIT 10000]입니다.
mysql 데이터베이스의 데이터를 일괄 삭제하는 방법:
1천만 개의 레코드가 있는 테이블(syslogs)이 있고 statusid=1인 모든 레코드를 거의 비즈니스를 중단하지 않고 삭제해야 한다고 가정합니다. 6백만 개의 항목이 있습니다. DELETE FROM syslogs WHERE statusid=1
을 직접 실행하면 잠금 대기 시간 초과 오류로 인해 삭제가 실패하는 것을 확인할 수 있습니다. DELETE FROM syslogs WHERE statusid=1
会发现删除失败,因为lock wait timeout exceed的错误。
因为这条语句所涉及的记录数太多,因此我们通过LIMIT
LIMIT
매개변수를 사용하여 일괄 삭제합니다. 예를 들어 10,000개의 레코드마다 삭제합니다. 그런 다음 MySQL과 같은 명령문을 사용하여 완료할 수 있습니다.
DELETE FROM syslogs WHERE status=1 ORDER BY statusid LIMIT 10000;
참고:
🎜더 많은 관련 무료 학습 권장 사항: mysql 튜토리얼(동영상)
위 내용은 mysql에서 데이터베이스의 데이터를 일괄 삭제하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!