DATEDIFF() se niega a ejecutarse en un evento MySQL

DATEDIFF() se niega a ejecutarse en un evento MySQL

Quiero crear un evento que se ejecute todos los días y ver si una cuenta caduca pronto. La soon_expirescelda será utilizada posteriormente por un script Bash que envía un correo electrónico al usuario relacionado informándole de la situación.

Este es el contenido de mi evento (usando phpmyadmin):

SELECT * FROM users;

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

Sin embargo, devuelve un error, diciendo

#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

También intenté crear un disparador, que funcionó según lo previsto. Pero me di cuenta de que un disparador se ejecutará solo cuando la fila se actualice; expirationtimees más o menos estático, por lo que un disparador no será suficiente.

Respuesta1

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

o

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

La primera variante actualiza todos los registros de la tabla, la segunda actualiza solo aquellos registros que caducan dentro de los 45 días.

información relacionada