> 데이터 베이스 > MySQL 튜토리얼 > 7일 후에 MySQL 레코드를 자동으로 삭제하는 방법은 무엇입니까?

7일 후에 MySQL 레코드를 자동으로 삭제하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2024-11-27 14:17:11
원래의
719명이 탐색했습니다.

How to Automatically Delete MySQL Records After Seven Days?

지속 기간 후 MySQL 레코드 삭제

이 게시물에서는 지정된 시간 간격 후에 MySQL 데이터베이스에서 레코드를 삭제하는 문제에 대해 설명하겠습니다.

문제:

다음이 포함된 MySQL 테이블의 메시지 'id', 'message', 'date' 열은 7일 후에 삭제해야 합니다. 날짜는 "YYYY-MM-DD HH:MM:SS" 형식으로 지정됩니다. 이 삭제 프로세스에는 크론 작업 대신 MySQL 이벤트를 사용하는 것이 좋습니다.

쿼리:

아래 쿼리에는 7보다 오래된 메시지를 삭제하기 위해 수정된 조건이 포함되어 있습니다. 일:

CREATE EVENT delete_event
ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 DAY
ON COMPLETION PRESERVE
DO BEGIN
    DELETE messages WHERE date < DATE_SUB(NOW(), INTERVAL 7 DAY);
END;
로그인 후 복사

설명:

질문에 제안된 조건을 사용하는 대신("DELETE message WHERE date >= (현재 날짜 - 7일) )"), "WHERE 날짜 < DATE_SUB(NOW(), INTERVAL 7 DAY)"를 사용합니다. 이렇게 하면 정확히 7일 된 메시지가 삭제되지만 이전 조건에서는 메시지가 삭제되지 않습니다.

권장사항:

이를 위해 MySQL 이벤트를 사용할 수 있습니다. 목적에 따라 간단한 cron 스크립트를 사용하는 것도 유효한 옵션입니다. 유지 관리가 더 쉽고, 복잡한 SQL 해결 방법이 없으며, 시스템과 원활하게 통합됩니다.

위 내용은 7일 후에 MySQL 레코드를 자동으로 삭제하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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