MySql——定时任务的应用

定时任务是什么?

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定时任务删除当天的考勤记录(会转存至另一张总的考勤记录表)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YSC7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值