mysql에서 데이터베이스의 데이터를 일괄 삭제하는 방법

coldplay.xixi
풀어 주다: 2020-09-28 13:16:10
원래의
4025명이 탐색했습니다.

데이터베이스의 데이터를 일괄 삭제하는 Mysql 방법: LIMIT 매개변수를 통해 일괄 삭제, 구문은 [DELETE FROM syslogs WHERE status=1 ORDER BY statusid LIMIT 10000]입니다.

mysql에서 데이터베이스의 데이터를 일괄 삭제하는 방법

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;
로그인 후 복사

그런 다음 여러 번 실행하여 이러한 레코드를 성공적으로 삭제하세요.

참고:

  • 대규모 일괄 삭제를 수행할 때는 제한을 사용하도록 주의하세요. 왜냐하면 Limit을 사용하지 않을 경우 대량의 데이터를 삭제하면 교착상태가 발생할 가능성이 높기 때문입니다.
  • 삭제된 where 문이 인덱스에 없으면 먼저 기본 키를 찾은 다음 기본 키를 기준으로 데이터베이스를 삭제할 수 있습니다.
  • 오용 방지를 위해 업데이트 및 삭제 시 제한 1을 추가하는 것이 가장 좋습니다.

더 많은 관련 무료 학습 권장 사항: mysql 튜토리얼(동영상)

🎜

위 내용은 mysql에서 데이터베이스의 데이터를 일괄 삭제하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿