MySQL定时任务(EVENT事件)如何配置详解
作者:_陈哈哈 发布时间:2024-01-19 08:04:12
一、事件(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
来源:https://blog.csdn.net/qq_39390545/article/details/109851072
猜你喜欢
- 一、绘制折线图import seaborn as snsimport numpy as npimport pandas as pdimpor
- 经常写文章的小伙伴可能会头疼,图片需要一张一张的上传,费劲也耗时,今天就推荐几款超简单的图床工具。图床就是一个在网络上存储图片的地方,目的是
- 教程使用的版本是2019.1新版本安装激活可以参考此篇教程,通用版!一、go安装1、建议去go语言中文网下载,网址:https://stud
- #coding:utf8import reimport urllibdef getHTML(url):
- tensorflow支持14种不同的类型,主要包括:实数:tf.float32 tf.float64整数:tf.int8 tf.int16
- 在Python中要连接数据库,首先我们得先安装几个重要的东西,主要有: (1)Python-dev包 (2)setupt
- 有时候我们需要判断某一个IP地址是否属于一个网段,以决定该用户能否访问系统.比如用户登录的IP是218.6.7.7,而我们的程序必须判断他是
- 代码如下# -*- coding:utf-8 -*-import cv2import numpy as npfrom tkinter imp
- MySQL-Group-Replication 是mysql-5.7.17版本开发出来的新特性;它在master-slave 之间实现了强一
- 如果不清楚字符串的编码格式的话,就可以将这段字符这样检查:$encode = mb_detect_encoding($string, arr
- 项目需要就在现有的服务器上面重新安装了个mysql服务器,还挺费劲儿呢,因为之前都是在我的笔记本上面试验的,它的系统是Ubuntu的,什么路
- <%@ Page Language="C#" %><!DOCTYPE html PUBLIC &quo
- 本文实例为大家分享了微信小程序实现列表下拉刷新上拉加载的具体代码,供大家参考,具体内容如下DEMO下载效果图原理利用微信小程序的onPull
- 啥也不说了,还是看代码吧! [root@yyjk DATABASE]# cat DBI.py# -*- coding: utf-8 -*-
- 我的机器不知为何,安装MySQL的时候,一到配置那一步就无休止的等待,只好结束任务,然而启动MySQL的时候出现1067错误提示
- 我就废话不多说了,直接上代码吧!# 寻找局部最高点# 输入input: 含有最高点高度的列表# 输出output: 返回最高点的位置# 时间
- 本文实例讲述了Python装饰器decorator用法。分享给大家供大家参考。具体分析如下:1. 闭包(closure)闭包是Python所
- ASP结合ADO对数据库方便快捷的访问、结合XML、COM/ActiveX等其它技术 实现服务器多层结构的功能使它在今天还有着顽强的生命力。
- pprint的英文全称Data pretty printer,顾名思义就是让显示结果更漂亮。print()和pprint()都是python
- tensorflow版本1.4获取变量维度是一个使用频繁的操作,在tensorflow中获取变量维度主要用到的操作有以下三种:Tensor.