%20%D0%BE%D1%82%D0%BA%D0%B0%D0%B7%D1%8B%D0%B2%D0%B0%D0%B5%D1%82%D1%81%D1%8F%20%D0%B7%D0%B0%D0%BF%D1%83%D1%81%D0%BA%D0%B0%D1%82%D1%8C%D1%81%D1%8F%20%D0%BF%D1%80%D0%B8%20%D1%81%D0%BE%D0%B1%D1%8B%D1%82%D0%B8%D0%B8%20MySQL.png)
Я хочу создать событие, которое будет запускаться каждый день и смотреть, скоро ли истечет срок действия учетной записи. Ячейка 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 дней.