Mysql事件调度程序每个月运行一次

时间:2013-10-07 13:41:30

标签: mysql events

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 ;

上述事件在月初开始只运行一次,但下个月开始没有运行,让我知道每个月的运行事件是如何开始的。

3 个答案:

答案 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需要超级用户访问服务器!)