DATEDIFF()가 MySQL 이벤트 실행을 거부합니다.

DATEDIFF()가 MySQL 이벤트 실행을 거부합니다.

매일 실행되는 이벤트를 만들고 계정이 곧 만료되는지 확인하고 싶습니다. 이 soon_expires셀은 나중에 관련 사용자에게 상황을 알리는 전자 메일을 보내는 Bash 스크립트에서 사용됩니다.

이것은 내 이벤트의 내용입니다(phpmyadmin 사용).

SELECT * FROM users;

IF DATEDIFF(expirationtime, CURDATE()) < 45 THEN
    SET soon_expires = 1; 
ELSE 
    SET soon_expires = 0; 
END IF;

그러나 다음과 같은 오류가 반환됩니다.

#1064: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'IF DATEDIFF(expirationtime, CURDATE()) < 45 THEN SET soon_expires = 1; EL' at line 3

또한 의도한 대로 작동하는 트리거를 만들려고 했습니다. 그러나 행이 업데이트될 때만 트리거가 실행된다는 것을 깨달았습니다. expirationtime다소 정적이므로 트리거로는 충분하지 않습니다.

답변1

CREATE EVENT check_expire
ON SCHEDULE
EVERY 1 DAY
STARTS '2019-08-21'
DO
UPDATE users
SET soon_expires = (DATEDIFF(expirationtime, CURRENT_DATE) < 45);

또는

UPDATE users
SET soon_expires = 1
WHERE DATEDIFF(expirationtime, CURRENT_DATE) < 45;

첫 번째 변종은 테이블의 모든 기록을 업데이트하고, 두 번째 변종은 45일 이내에 만료되는 기록만 업데이트합니다.

관련 정보