MySQL的事件调度器是内置的定时任务功能,支持创建一次性事件和周期性事件,其中一次性事件可以在指定的未来时间点自动执行,执行完成后不会重复触发。要创建指定时间间隔后执行的一次性事件,首先需要确保事件调度器处于开启状态。

开启MySQL事件调度器
默认情况下,MySQL的事件调度器可能是关闭的,我们需要先检查并开启它。可以通过执行以下SQL语句查看事件调度器的状态:
-- 查看事件调度器状态 SHOW VARIABLES LIKE 'event_scheduler';
如果返回的结果是OFF,可以通过以下语句临时开启,重启MySQL后会恢复默认关闭状态:
-- 临时开启事件调度器 SET GLOBAL event_scheduler = ON;
如果需要永久开启,需要修改MySQL的配置文件,在[mysqld] section下添加event_scheduler=ON,然后重启MySQL服务即可。
创建一次性事件的语法
创建一次性事件的核心语法如下,我们可以指定事件在未来某个时间间隔后执行:
CREATE EVENT [IF NOT EXISTS] 事件名称 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 时间间隔 时间单位 DO 事件执行的逻辑语句;
语法中的各部分说明:
IF NOT EXISTS:可选参数,避免事件名称重复时报错事件名称:自定义的事件标识,需要保证唯一性AT CURRENT_TIMESTAMP + INTERVAL 时间间隔 时间单位:指定事件执行的时间,CURRENT_TIMESTAMP是当前时间,加上后面的时间间隔就是未来的执行时间DO后面跟随的是事件触发时要执行的SQL逻辑,可以是单条语句,也可以是多条语句包裹在BEGIN...END中
实际示例演示
假设我们需要创建一个一次性事件,在当前时间之后10分钟,自动删除temp_data表中超过7天的临时数据,具体创建语句如下:
-- 创建一次性事件,10分钟后执行临时数据清理 CREATE EVENT IF NOT EXISTS clean_temp_data_once ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 10 MINUTE DO DELETE FROM temp_data WHERE create_time < CURRENT_TIMESTAMP - INTERVAL 7 DAY;
如果事件需要执行多条SQL语句,比如同时清理两张表的数据并记录清理日志,可以使用BEGIN...END包裹逻辑:
-- 执行多条语句的一次性事件示例
CREATE EVENT IF NOT EXISTS multi_task_once
ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 30 MINUTE
DO
BEGIN
-- 清理临时表1数据
DELETE FROM temp_table1 WHERE expire_time < CURRENT_TIMESTAMP;
-- 清理临时表2数据
DELETE FROM temp_table2 WHERE expire_time < CURRENT_TIMESTAMP;
-- 插入清理记录
INSERT INTO clean_log (task_name, clean_time) VALUES ('multi_temp_clean', CURRENT_TIMESTAMP);
END
查看和管理已创建的事件
创建完成后,我们可以通过以下语句查看所有事件的信息:
-- 查看所有事件 SHOW EVENTS;
如果需要查看某个具体事件的详细信息,可以使用:
-- 查看指定事件的详细信息 SHOW CREATE EVENT clean_temp_data_once;
如果不再需要某个一次性事件,即使它已经执行完成,也可以手动删除:
-- 删除指定事件 DROP EVENT IF EXISTS clean_temp_data_once;
注意事项
- 一次性事件执行完成后,默认不会被自动删除,需要手动执行
DROP EVENT删除,或者创建时添加ON COMPLETION NOT PRESERVE参数,让事件执行后自动删除 - 事件执行的逻辑需要有对应的权限,比如删除表数据需要有对应表的DELETE权限,否则事件会执行失败
- 时间间隔支持的时间单位包括YEAR、MONTH、DAY、HOUR、MINUTE、SECOND等,可以根据实际需求选择
- 如果MySQL服务在事件预定执行的时间点处于关闭状态,事件会在服务重启后,事件调度器重新开启时立即执行,前提是事件还没有被删除
如果需要创建执行后自动删除的一次性事件,可以在创建语句中添加ON COMPLETION NOT PRESERVE,示例:
-- 执行后自动删除的一次性事件 CREATE EVENT IF NOT EXISTS auto_drop_event ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 HOUR ON COMPLETION NOT PRESERVE DO UPDATE config SET value = '1' WHERE config_key = 'task_flag';