在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
一、事件(EVENT)是干什么的 自MySQL 事件有时也可以称为临时触发器(temporal triggers),因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。 二、开启“事件”功能使用“事件”功能之前必须确保event_scheduler已开启 1、查询功能是否开启:-- 方法一 SELECT @@event_scheduler; -- 方法二 SHOW VARIABLES LIKE 'event%'; 显示 “ON”说明功能已开启;如下图: mysql> SELECT @@event_scheduler; +-------------------+ | @@event_scheduler | +-------------------+ | ON | +-------------------+ 1 row in set (0.00 sec) mysql> SHOW VARIABLES LIKE 'event%'; +-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | event_scheduler | ON | +-----------------+-------+ 1 row in set (0.00 sec) 2、开启、关闭功能命令: -- 开启功能命令: SET GLOBAL event_scheduler = 1; SET GLOBAL event_scheduler = ON; -- 关闭功能命令: SET GLOBAL event_scheduler = 0; SET GLOBAL event_scheduler = OFF; 当然,通过命令开启当数据库重启后会自动关闭;
常用的事件操作命令:
三、事件 - SQL语法创建下面是EVENT事件创建语句,乍一看挺复杂的,让我们拆开解读一下 CREATE EVENT [IFNOT EXISTS] event_name ON SCHEDULE schedule(调度时间设置) [ON COMPLETION [NOT] PRESERVE] [ENABLE | DISABLE | DISABLE ON SLAVE] [COMMENT 'comment'] DO sql_statement;
AT timestamp [+ INTERVAL interval] ... | EVERY interval [STARTS timestamp [+ INTERVAL interval] ...] [ENDS timestamp [+ INTERVAL interval] ...] -- INTERVAL中包含的时间单位如下: {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE | WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND} 1、创建 - 单次定时执行事件AT TIMESTAMP 时间字符串 [+ INTERVAL INTERVAL] AT TIMESTAMP表示该事件只执行一次,TIMESTAMP表示一个具体的时间点,后面可以加上一个时间间隔,表示在这个时间间隔后事件发生。[+ INTERVAL INTERVAL]表示延迟触发时间; 需要注意的是,TIMESTAMP和具体字符串连用,如果不是具体字符串(如CURRENT_TIMESTAMP取当前时间等),则不加TIMESTAMP; 示例 1:往demo_1119表中插入一行数据,执行时间:2020-11-20 00:00:00 CREATE EVENT demo_event2 ON SCHEDULE AT TIMESTAMP '2020-11-20 00:00:00' DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) 结果查询: mysql> select * from demo_1119; +-----+-----------+---------------------+ | id | name | createTime | +-----+-----------+---------------------+ | 145 | 陈哈哈 | 2020-11-20 00:00:00 | +-----+-----------+---------------------+ 9 rows in set (0.00 sec) 示例 2:往demo_1119表中插入一行数据,执行时间:当前时间往后5个小时; CREATE EVENT demo_event2 ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 HOUR DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) 2、创建 - 循环定时执行事件EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]
示例 1:从当前开始,每10秒往demo_1119表中插入一行数据 CREATE EVENT demo_event3 ON SCHEDULE EVERY 10 SECOND ON COMPLETION PRESERVE DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) mysql> select * from demo_1119; +-----+-----------+---------------------+ | id | name | createTime | +-----+-----------+---------------------+ | 145 | 陈哈哈 | 2020-11-19 11:10:39 | | 146 | 陈哈哈 | 2020-11-19 11:10:49 | | 147 | 陈哈哈 | 2020-11-20 11:10:59 | | 148 | 陈哈哈 | 2020-11-20 11:11:09 | | 149 | 陈哈哈 | 2020-11-20 11:11:19 | | 150 | 陈哈哈 | 2020-11-20 11:11:29 | | 151 | 陈哈哈 | 2020-11-20 11:11:39 | +-----+-----------+---------------------+ 9 rows in set (0.00 sec) 示例 2:从2020-11-20 12:00:00开始,每10分钟往demo_1119表中插入一行数据 CREATE EVENT demo_event4 ON SCHEDULE EVERY 10 MINUTE STARTS '2020-11-20 12:00:00' ON COMPLETION PRESERVE DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) mysql> select * from demo_1119; +-----+-----------+---------------------+ | id | name | createTime | +-----+-----------+---------------------+ | 152 | 陈哈哈 | 2020-11-20 12:00:00 | | 153 | 陈哈哈 | 2020-11-20 12:10:00 | | 154 | 陈哈哈 | 2020-11-20 12:20:00 | | 155 | 陈哈哈 | 2020-11-20 12:30:00 | | 156 | 陈哈哈 | 2020-11-20 12:40:00 | +-----+-----------+---------------------+ 5 rows in set (0.00 sec) 示例 3:从当前时间一小时后开始,每10分钟往demo_1119表中插入一行数据;已经测试过可用,我就不再贴冗余查询的数据咯~ CREATE EVENT demo_event5 ON SCHEDULE EVERY 10 MINUTE STARTS CURRENT_TIMESTAMP+INTERVAL 1 HOUR ON COMPLETION PRESERVE DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) 示例4:从当前时间一天后开始,每1小时往demo_1119表中插入一行数据,三天后结束 CREATE EVENT demo_event5 ON SCHEDULE EVERY 1 HOUR STARTS CURRENT_TIMESTAMP+INTERVAL 1 DAY ENDS CURRENT_TIMESTAMP+INTERVAL 3 DAY ON COMPLETION PRESERVE DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陈哈哈', NOW()) 示例5:每天零点定时清一下demo_1119表数据 CREATE EVENT demo_event5 ON SCHEDULE EVERY 1 DAY STARTS '2020-11-20 00:00:00' ON COMPLETION PRESERVE DO TRUNCATE table `demo_1119` 3、修改事件修改事件语句跟创建语句如出一辙,语法如下: ALTER EVENT event_name [ONSCHEDULE schedule] [old_NAME TO new_NAME] [ON COMPLETION [NOT] PRESERVE] [COMMENT 'comment'] [ENABLE | DISABLE] [DO sql_statement] 关闭事件任务: ALTER EVENT 事件名称 ON COMPLETION PRESERVE DISABLE; 开启事件任务:ALTER EVENT 事件名称 ON COMPLETION PRESERVE ENABLE; 4、删除事件DROP EVENT [IF EXISTS] event_name 四、事件 - 用Navicat创建(推荐)很多小伙伴喜欢在命令行敲SQL语句,会有种专业感,但也可能是被领导道德绑架了~~ 就像有些领导们觉得自己员工用Google就很cool😎😎,很带劲;用百度查 csdn 就很 low。 但作为菜狗的我还是喜欢用我的Navicat小工具和度娘。好了废话不多说,我们来看看Navicat是如何创建EVENT事件的,GO! 如下图,右键点击创建新的事件
创建事件中的
当然也可以同时写多条SQL,中间带分号。以BEGIN开头,END结尾即可。 打开计划栏,是不是觉得很熟悉!在上个模块我们都见过。为了使小伙伴们加深印象,我们在回顾一下吧。
参数说明:
INTERVAL中包含的时间单位如下:
好了,让我们通过一些实例来加深印象: 示例 1:往demo_1119表中插入一行数据,执行时间:2020-11-20 00:00:00 示例 2:往demo_1119表中插入一行数据,执行时间:当前时间往后5个小时; 示例 3:从当前开始,每10秒往demo_1119表中插入一行数据 示例 4:从2020-11-20 12:00:00开始,每10分钟往demo_1119表中插入一行数据 示例 5:从当前时间一小时后开始,每10分钟往demo_1119表中插入一行数据; 示例 6:从当前时间一天后开始,每1小时往demo_1119表中插入一行数据,三天后结束 示例 7:每天零点定时清一下demo_1119表数据 到此这篇关于MySQL定时任务(EVENT事件)如何配置详解的文章就介绍到这了,更多相关MySQL定时任务内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论