이 게시물에서는 지정된 시간 간격 후에 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!