MySQL创建定时任务实例(每天凌晨1点、每小时、每分钟、某一时间点)

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

MySQL创建定时任务实例(每天凌晨1点、每小时、每分钟、某一时间点)

黄饱饱_bao   2023-03-23 我要评论

常用的一定要写在前面

# 从2019-10-11开始,每天的00:30:00执行定时任务
ON SCHEDULE EVERY 1 DAY STARTS '2019-10-11 00:30:00'  
 
# 每天的凌晨1点执行定时任务
ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 1 HOUR)
 
# 特定的日期特定的时间点执行定时任务
ON SCHEDULE at '2019-10-10 19:14:10'
 
# 每五分钟执行一次定时任务
ON SCHEDULE EVERY 5 MINUTE STARTS CURDATE() 
 
# 每小时执行一次定时任务
ON SCHEDULE EVERY 1 HOUR STARTS CURDATE() 

下面开始进入正文!!!

就像增删改查需要权限一样,建立定时任务也需要权限!

一、查看定时策略是否开启

show variables like '%event_sche%';

如果显示为

ON:表示已开启,下面这些就不用做了,直接进入【二、创建定时任务】

OFF:表示没有开启!

set global event_scheduler=1;-- 开启定时

执行完这一句,如果显示access denied;

表示你没有开启定时任务的权限,联系运维给你开通权限,或者让他执行一下上面这个语句。

执行完之后再执行一下show variables like '%event_sche%';确保已开启。

二、创建定时任务

以下语句也是在新建查询窗口运行

方法1:直接创建定时任务事件

DELIMITER //
CREATE EVENT test_event 
on schedule at '2019-10-10 19:27:10' #规定在这个时间点执行下面的语句
DO
BEGIN
 
DROP TABLE IF EXISTS test_ee;
/************************************************************************/
CREATE table test_ee AS SELECT NOW()
;
 
END;
//

方法2:先创建存储过程,再定义执行周期

-- 创建存储过程test
CREATE PROCEDURE test_d2 ()
BEGIN
 
DROP TABLE IF EXISTS test_ddd;
/*************************************/
CREATE table test_ddd AS SELECT NOW()
;
END;
 
 
CREATE EVENT IF NOT EXISTS temp_event   
    on schedule at '2019-10-10 19:14:10'
    ON COMPLETION PRESERVE -- ENABLE   
do call test_d2();

总结

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们