DELIMITER $$
ALTER DEFINER=`root`@`localhost` EVENT `update_start_date` ON SCHEDULE EVERY 1 MONTH
DO
UPDATE categories SET start_date=now() where status = 1 $$
DELIMITER ;
上述事件在月初开始只运行一次,但下个月开始没有运行,让我知道每个月的运行事件是如何开始的。
答案 0 :(得分:0)
我认为你应该使用“cron”这个
答案 1 :(得分:0)
我个人建议您使用cron或其他一些外部计划管理系统。
如果你必须到mySQL来处理日程安排:
DELIMITER $$
ALTER DEFINER=`root`@`localhost` EVENT `update_start_date` ON SCHEDULE EVERY 1 MONTH START NOW()
DO
UPDATE categories SET start_date=now() where status = 1 $$
END$$
DELIMITER ;
答案 2 :(得分:0)
您需要查看http://dev.mysql.com/doc/refman/5.1/en/events.html了解更多详情,但这是一个简单的版本。
首先,您需要启用调度程序 - >
SET GLOBAL event_scheduler = ON;
然后安排实际的事情
DELIMITER $$
CREATE EVENT IF NOT EXISTS event_name ON SCHEDULE EVERY MONTH
STARTS CURRENT_TIMESTAMP + INTERVAL 1 DAY
ON COMPLETION PRESERVE
ENABLE
COMMENT 'comment'
DO BEGIN
//SQL statements here.
END $$
DELIMITER ;
请注意,这需要超级用户访问您的MySQL数据库(CRON需要超级用户访问服务器!)