MySQL定时任务(EVENT事件)如何配置详解(MySQL定时任务EVENT事件如何配置详解)
MySQL定时任务(EVENT事件)如何配置详解
MySQL定时任务EVENT事件如何配置详解目录
- 一、事件(EVENT)是干什么的
-
二、开启“事件”功能
- 1、查询功能是否开启:
-
三、事件 - SQL语法创建
- 1、创建 - 单次定时执行事件
- 2、创建 - 循环定时执行事件
- 3、修改事件
- 4、删除事件
- 四、事件 - 用Navicat创建(推荐)
一、事件(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定时任务内容请搜索萬仟网以前的文章或继续浏览下面的相关文章希望大家以后多多支持萬仟网!
原文链接:https://blog.csdn.net/qq_39390545/article/details/109851072
- mysql索引优化有哪些(MySQL如何基于Explain关键字优化索引功能)
- mysql长连接释放和不释放的问题(解决MySQL存储时间出现不一致的问题)
- mysql中修改表的字段名(MySQL 使用SQL语句修改表名的实现)
- mysql分区表的优缺点(MySQL数据表分区策略及优缺点分析)
- mysql中date_format日期格式化
- mysql中定义字段时zerofill属性的作用
- innodb和myisam(Mysql InnoDB和MyISAM区别原理解析)
- mysql删除表内所有数据(mysql 大表批量删除大量数据的实现方法)
- mysql忽略大小写(MySQL大小写敏感的注意事项)
- mysql主从模式与读写分离(磁盘写满导致MySQL复制失败的解决方案)
- 将SQL Server数据迁移到MySQL的方法
- mysql复合索引会包含哪些索引(MySQL查询冗余索引和未使用过的索引操作)
- mysql为什么用decimal类型(MySQL decimal unsigned更新负数转化为0)
- mysql面试题及答案100题(几个MySQL高频面试题的解答)
- navicat15.0.28注册码(Navicat for MySQL 11注册码激活码汇总)
- windows mysql 忘记密码(解决MySQL忘记密码问题的方法)
- 鲢鳙钓底还是钓浮 流水的水域应怎样做钓(鲢鳙钓底还是钓浮)
- 入秋后的第二场苹果发布会来了 全新M1系列芯片登场(入秋后的第二场苹果发布会来了)
- 苹果正式发布自研芯片M1 5nm 32核心 彻底放弃Intel(苹果正式发布自研芯片M1)
- 苹果自研芯片跑分对比 A16芯片排名靠后,M1系列霸榜(苹果自研芯片跑分对比)
- X86处理器的梦魇 苹果M1自研芯片到底有多强(苹果M1自研芯片到底有多强)
- 泰剧《爱欲之神》Boom kitkong和Great合体杂志(泰剧爱欲之神Boomkitkong和Great合体杂志)
热门推荐
- centos7可以装mysql吗(详解腾讯云CentOS7.0使用yum安装mysql及使用遇到的问题)
- python有什么好的微信公众号(python下载微信公众号相关文章)
- php定时执行PHP(Cpanel下Cron Jobs定时执行PHP的方法)
- django用户权限管理(Django 内置权限扩展案例详解)
- sqlserver2012海量数据查询(SQL Server 2012 多表连接查询功能实例代码)
- css3定义自定义字体(CSS3字体效果的设置方法小结)
- mysql访问被拒绝(nacos无法连接mysql的解决方法)
- python语言翻译中文(浅析Python 实现一个自动化翻译和替换的工具)
- php表单上传文件功能(PHP单文件上传原理及上传函数的封装操作示例)
- ui界面的测试用例(AmazeUI中模态框的实现)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9