定时任务是什么?
MySQL5.1.6起增加了事件调度器(Event Scheduler),可用来做定时执行某些特定任务,用于取代原先只能由操作系统的计划任务来执行的工作。MySQL的事件调度器可以精确到每秒执行一个任务,而操作系统的计划任务只能精确到分钟级别。对于对数据实时性要求比较高的应用非常合适。
事件调度器与触发器的区别
事件调度器也称为临时触发器(Temporal Triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的。
用法
1、选择一个数据库
use 数据库名;
2、开启事件调度器
SET GLOBAL event_scheduler=1;
3、验证事件调度器是否已开启
show variables like '%event%'; #值为 ON 表明已开启
SHOW VARIABLES LIKE 'event_scheduler';
4、创建事件调度器(以每天定时消除某张表数据为例)
DROP EVENT IF EXISTS e_delete_upvote;
CREATE EVENT e_delete_upvote
ON SCHEDULE EVERY 1 day STARTS DATE_ADD(current_date(),INTERVAL 1 DAY) ON COMPLETION PRESERVE ENABLE
DO TRUNCATE TABLE 所需清楚数据的表名;
说明:
ON SCHEDULE EVERY 1 day 指定循环间隔为每天执行;
STARTS date_add(concat(current_date(), ‘23:59:00’), interval 0 second) 指定运行时间为23:59:00 ON COMPLETION PRESERVE ENABLE ;
指定创建完成后即启用,否则需手动启动;
DO TRUNCATE TABLE 清楚指定表;
5、手动关闭事件
ALTER EVENT e_delete_upvote DISABLE;
6、手动开启事件
ALTER EVENT e_delete_upvote ENABLE;
7、删除事件
DROP EVENT e_delete_upvote;
应用场景
最近在完成 毕设—基于人脸识别的学生考勤系统,在本项目中,使用Mysql定时任务删除当天的考勤记录(会转存至另一张总的考勤记录表)