0
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 ;

上述活动在月初只运行一次,但下个月开始不运行,让我知道每个月开始时如何运行事件。

4

3 回答 3

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

于 2013-10-07T13:52:57.287 回答
0

我认为您应该为此使用“cron”

于 2013-10-07T13:46:37.713 回答
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 ;
于 2013-10-07T13:49:26.803 回答