MySQL定时任务(EVENT事件)如何配置详解
IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《MySQL定时任务(EVENT事件)如何配置详解》,聊聊MySQL定时任务,我们一起来看看吧!
一、事件(EVENT)是干什么的
自MySQL5.1.6
起,增加了一个非常有特色的功能 - 事件调度器
(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、数据统计报告、数据备份等等),来取代原先只能由操作系统的计划任务来执行的工作。
值得一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:Linux的cron)只能精确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就非常适合。
事件有时也可以称为临时触发器(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;
当然,通过命令开启当数据库重启后会自动关闭;
持久化开启方式
:将event_scheduler=1
写到my.cnf配置文件中;如下图:
常用的事件操作命令:
- 关闭指定事件: ALTER EVENT 事件名称 ON COMPLETION PRESERVE DISABLE;
- 开启指定事件:ALTER EVENT 事件名称 ON COMPLETION PRESERVE ENABLE;
- 查看当前事件:SHOW EVENTS ;
三、事件 - 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;
SQL语法 | 说明 |
---|---|
DEFINER | 可选项,给指定用户使用权限 |
IF NOT EXISTS | 可选项,用于判断要创建的事件是否存在 |
EVENT event_name | 必选项,指定事件名称,event_name的最大长度为64个字符,如果为指定event_name,则默认为当前的MySQL用户名(不区分大小写) |
ON SCHEDULE schedule | 必选项,这里的schedule用于定义执行的时间和时间间隔,在下面我们详细讲解 |
ON COMPLETION [NOT] PRESERVE | 可选项,配置事件执行完一次后的处理方式; 当为on completion preserve 的时候,当event到期了,event会被disable,但是该event还是会存在 当为on completion not preserve的时候,当event到期的时候,该event会被自动删除掉. |
ENABLE、DISABLE、DISABLE ON SLAVE | 可选项,用于指定事件的一种属性。 ENABLE表示该事件是开启的,也就是调度器检查事件是否必选调用; DISABLE表示该事件是关闭的,也就是事件的声明存储到目录中,但是调度器不会检查它是否应该调用; DISABLE ON SLAVE表示事件在从机中是关闭的。如果不指定这三个选择中的任意一个,则在一个事件创建之后,它立即变为活动的。 |
COMMENT ‘comment' | 可选项,用于定义事件的注释 |
DO event_body | 必选项,用于指定事件启动时所要执行的代码。可以是任何有效的SQL语句、存储过程或者一个计划执行的事件。如果包含多条语句,可以使用BEGIN…END复合结构 |
schedule
调度时间配置语法:调度时间配置包括AT
和 EVERY
两种
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]
EVERY表示循环执行该事件
,其中STARTS
子句用于指定开始时间;ENDS
子句用于指定结束时间。
示例 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的,可以包括一条或多条SQL语句、存储过程等,计划
一栏是定义事件触发时间的。如下图,我在执行过程中定义了一条插入语句。
当然也可以同时写多条SQL,中间带分号。以BEGIN开头,END结尾即可。
打开计划栏,是不是觉得很熟悉!在上个模块我们都见过。为了使小伙伴们加深印象,我们在回顾一下吧。
参数说明:
AT
:表示该事件只执行一次,可以设置一个具体的时间,也可以如图中CURRENT_TIMESTAMP
代表当前时间,后面可以加上一个时间间隔interval
,表示在这个时间多久以后后事件发生,表示延迟触发时间;
EVERY
:循环执行该事件,其中STARTS
子句用于指定开始时间;ENDS
子句用于指定结束时间。interval
:表示从现在开始时间延迟多久以后的一个时间点
,其值由一个数值和单位构成。例如,使用“4 WEEK”表示4周后;使用“‘1:10' HOUR_MINUTE”表示1小时10分钟后。间隔的距离用DATE_ADD()函数来支配。
INTERVAL中包含的时间单位如下:
YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE | WEEK | SECOND |
YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND
好了,让我们通过一些实例来加深印象: 示例 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的资料请关注golang学习网公众号!

- 上一篇
- mysql实现自增序列的示例代码

- 下一篇
- 从云数据迁移服务看MySQL大表抽取模式的原理解析
-
- 完美的黑猫
- 这篇技术文章真及时,好细啊,真优秀,码起来,关注老哥了!希望老哥能多写数据库相关的文章。
- 2023-05-02 11:35:39
-
- 喜悦的帽子
- 太全面了,已收藏,感谢大佬的这篇文章,我会继续支持!
- 2023-02-05 12:15:02
-
- 典雅的大地
- 好细啊,已加入收藏夹了,感谢博主的这篇博文,我会继续支持!
- 2023-01-05 14:35:48
-
- 善良的画板
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享文章!
- 2023-01-04 11:46:41
-
- 开朗的海燕
- 这篇文章太及时了,作者大大加油!
- 2022-12-31 04:27:53
-
- 安静的小刺猬
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者大大分享文章!
- 2022-12-30 00:39:01
-
- 凶狠的水杯
- 这篇技术贴出现的刚刚好,很详细,太给力了,已加入收藏夹了,关注作者了!希望作者能多写数据库相关的文章。
- 2022-12-29 15:00:24
-
- 数据库 · MySQL | 14小时前 | 索引 数据类型 字符集 存储引擎 CREATETABLE
- MySQL新建表操作指南与建表技巧
- 462浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 条件判断
- CASEWHEN条件判断的嵌套使用详解与实战场景分析
- 469浏览 收藏
-
- 数据库 · MySQL | 1个月前 | java php
- CSV文件批量导入MySQL的性能优化秘籍大揭秘
- 289浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- GaleraCluster多主集群配置与冲突解决攻略
- 239浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 窗口函数实战
- MySQL窗口函数实战案例深度剖析
- 315浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 自定义函数
- MySQL插件开发入门:自定义函数(UDF)编写指南
- 184浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- Windows系统MySQL8.0免安装版配置攻略
- 227浏览 收藏
-
- 数据库 · MySQL | 1个月前 | MySQL错误 数据库诊断
- 深度解析错误代码1045/1217/1205的根本原因及解决方案
- 202浏览 收藏
-
- 数据库 · MySQL | 1个月前 | sql注入 编码规范
- 防范SQL注入必备:编码规范与工具推荐指南
- 140浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 14次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 22次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 30次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 40次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 35次使用
-
- MySQL定时任务不能正常执行的原因分析及解决方法
- 2022-12-31 247浏览