在 MySQL 中,你可以使用事件调度器(Event Scheduler)来创建定时器,以在指定时间自动执行存储过程。以下是在每天晚上1点钟调用存储过程proc_task的示例:
首先,确保 MySQL 事件调度器已经启用。如果尚未启用,可以在 MySQL 客户端中执行以下命令:
SET GLOBAL event_scheduler = ON;
然后,创建定时器:
DELIMITER //
CREATE EVENT IF NOT EXISTS my_daily_event
ON SCHEDULE EVERY 1 DAY
STARTS CURRENT_TIMESTAMP + INTERVAL 1 DAY
ON COMPLETION PRESERVE
DO
BEGIN
-- 调用存储过程 proc_task
CALL proc_task();
END //
DELIMITER ;
DELIMITER // 是为了更好地处理包含多行内容的语句。
CREATE EVENT IF NOT EXISTS my_daily_event 创建一个名为my_daily_event的事件,如果该事件已经存在则不创建。
ON SCHEDULE EVERY 1 DAY 定义事件执行的频率,这里设置为每天执行一次。
STARTS CURRENT_TIMESTAMP + INTERVAL 1 DAY 定义事件的开始时间,这里设置为当前时间的下一天1点钟。
ON COMPLETION PRESERVE 定义当事件完成时的处理方式。PRESERVE表示保留事件,不删除它。
DO 后面是事件要执行的内容,这里使用 BEGIN...END 块调用存储过程 proc_task()。
请注意,定时器的创建需要具有相应权限的用户执行。确保你有足够的权限来创建事件调度器和调用存储过程。另外,定时器会在每天的1点钟触发,并执行存储过程 proc_task()。