Chia cảnh báo thành 2 trường
Alert_count: integer
Alert_period: enum('hour','day','month','week')
Và thay đổi truy vấn như vậy:
SELECT *
FROM `activities`
WHERE CASE alert_period
WHEN 'hour' THEN date_sub(`deadline`, INTERVAL alert_count HOUR) >= CURDATE();
WHEN 'day' THEN date_sub(`deadline`, INTERVAL alert_count DAY) >= CURDATE();
...
END CASE