MySQL定时任务(EVENT事件)如何配置详解

 更新时间:2021年02月07日 10:16:32   作者:_陈哈哈  
这篇文章主要介绍了MySQL定时任务(EVENT事件)如何配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

一、事件(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 调度时间配置语法:调度时间配置包括ATEVERY两种

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定时任务内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • sql中select into和insert select的用法小结

    sql中select into和insert select的用法小结

    在工作中,我们经常需要备份表,本文主要介绍了sql中select into和insert select的用法小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-08-08
  • 深入理解Mysql的四种隔离级别

    深入理解Mysql的四种隔离级别

    开发工作中我们会使用到事务,那你们知道事务又分哪几种吗?MYSQL标准定义了4类隔离级别,用来限定事务内外的哪些改变是可见的,哪些是不可见的。低的隔离级一般支持更高的并发处理,并拥有更低的系统开销。下面通过这篇文章我们来一起深入理解Mysql中的四种隔离级别。
    2016-11-11
  • MySQL压力测试工具Mysqlslap的使用

    MySQL压力测试工具Mysqlslap的使用

    这篇文章主要介绍了MySQL官方压力测试工具 Mysqlslap的使用方法,帮助大家更好的理解和使用MySQL,感兴趣的朋友可以了解下
    2020-12-12
  • MySQL 数据恢复的多种方法汇总

    MySQL 数据恢复的多种方法汇总

    日常工作中,总会有因手抖、写错条件、写错表名、错连生产库造成的误删库表和数据的事情发生。但是,如果每次删库都跑路的话,怕是再也不好找工作了吧!所以,删库跑路不是上上策
    2021-06-06
  • 手把手教你Navicat如何导出Excel格式的表结构

    手把手教你Navicat如何导出Excel格式的表结构

    我们在开发中使用数据库时往往需要做一些备份之类的,或者需要导出下表结构导入到其他数据库等,下面这篇文章主要给大家介绍了关于Navicat如何导出Excel格式的表结构的相关资料,需要的朋友可以参考下
    2023-04-04
  • MYSQL导入导出sql文件简析

    MYSQL导入导出sql文件简析

    这篇文章主要介绍了MYSQL导入导出.sql文件的相关资料,内容包括MYSQL的命令行模式的设置、命令行进入MYSQL的方法、数据库导出数据库文件、从外部文件导入数据到数据库,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • MySql设置指定用户数据库查看查询权限

    MySql设置指定用户数据库查看查询权限

    这篇文章主要介绍了MySql设置指定用户数据库查看查询权限,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Mysql存储过程学习笔记--建立简单的存储过程

    Mysql存储过程学习笔记--建立简单的存储过程

    我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它。
    2014-08-08
  • Centos 6.4源码安装mysql-5.6.28.tar.gz教程

    Centos 6.4源码安装mysql-5.6.28.tar.gz教程

    这篇文章主要为大家详细介绍了Centos 6.4源码安装mysql-5.6.28.tar.gz教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-01-01
  • MySQL优化之如何了解SQL的执行频率

    MySQL优化之如何了解SQL的执行频率

    MySQL 客户端连接成功后,通过 show [session|global]status 命令 可以提供服务器状态信息,也可以在操作系统上使用 mysqladmin extended-status 命令获得这些消息
    2014-05-05

最新评论