当前位置:Gxlcms > 数据库问题 > mysql定时任务(event事件)

mysql定时任务(event事件)

时间:2021-07-01 10:21:17 帮助过:14人阅读

名词解释:
event_name :创建的event名字(唯一确定的)。
ON SCHEDULE:计划任务。
schedule: 决定event的执行时间和频率(注意时间一定要是将来的时间,过去的时间会出错),有两种形式 AT和EVERY。
[ON COMPLETION [NOT] PRESERVE]: 可选项,默认是ON COMPLETION NOT PRESERVE 即计划任务执行完毕后自动drop该事件;ON COMPLETION PRESERVE则不会drop掉。
[COMMENT ‘comment‘] :可选项,comment 用来描述event;相当注释,最大长度64个字节。
[ENABLE | DISABLE] :设定event的状态,默认ENABLE:表示系统尝试执行这个事件, DISABLE:关闭该事情,可以用alter修改
DO event_body: 需要执行的sql语句(可以是复合语句)。CREATE EVENT在存储过程中使用时合法的。

3.2 开启关闭事件调度器
3.2.1 MySQL事件调度器event_scheduler负责调用事件,它默认是关闭的。这个调度器不断地监视一个事件是否要调用, 要创建事件,必须打开调度器。

mysql> show variables like ‘%event_scheduler%‘; 
+-----------------+-------+ 
| Variable_name   | Value | 
+-----------------+-------+ 
| event_scheduler | OFF   | 
+-----------------+-------+ 

3.2.2 开启事件调度器
通过命令行
可通过如下任何一个命令行

SET GLOBAL event_scheduler = ON; 
SET @@global.event_scheduler = ON; 
SET GLOBAL event_scheduler = 1; 
SET @@global.event_scheduler = 1; 

通过配置文件my.cnf

event_scheduler = 1 #或者ON 

查看调度器线程

mysql> show processlist; 
+----+-----------------+-----------+------+---------+------+------------------------+------------------+ 
| Id | User            | Host      | db   | Command | Time | State                  | Info             | 
+----+-----------------+-----------+------+---------+------+------------------------+------------------+ 
|  2 | root            | localhost | NULL | Query   |    0 | NULL                   | show processlist | 
|  3 | event_scheduler | localhost | NULL | Daemon  |    6 | Waiting on empty queue | NULL| 
+----+-----------------+-----------+------+---------+------+------------------------+------------------+ 

3.2.3 关闭事件调度器
通过命令行
可通过如下任何一个命令行

SET GLOBAL event_scheduler = OFF; 
SET @@global.event_scheduler = OFF; 
SET GLOBAL event_scheduler = 0; 
SET @@global.event_scheduler = 0; 

通过配置文件my.cnf
在[mysqld]下增加

event_scheduler = 0 #或者OFF,DISABLED 

查看调度器线程

mysql> show processlist; 
+----+------+-----------+------+---------+------+-------+------------------+ 
| Id | User | Host      | db   | Command | Time | State | Info             | 
+----+------+-----------+------+---------+------+-------+------------------+ 
|  2 | root | localhost | NULL | Query   |    0 | NULL  | show processlist | 
+----+------+-----------+------+---------+------+-------+------------------+

3.3 例如:创建一个表记录每次事件调度的名字和事件戳
3.3.1 创建测试表

mysql> drop table if exists events_list; 
mysql> create table events_list(event_name varchar(20) not null, event_started timestamp not null); 

3.3.2 创建事件1(立即启动事件)

create event event_now  
on schedule  
at now()  
do insert into events_list values(‘event_now‘, now()); 

查看事件执行结果

mysql> select * from events_list; 
+------------+---------------------+ 
| event_name | event_started       | 
+------------+---------------------+ 
| event_now  | 2014-07-01 04:06:40 | 
+------------+---------------------+ 

3.3.3 创建事件2(每分钟启动事件)

create event test.event_minute  
on schedule  
every  1 minute   
do insert into events_list values(‘event_now‘, now()); 

查看事件执行结果

mysql> select * from events_list; 
+------------+---------------------+ 
| event_name | event_started       | 
+------------+---------------------+ 
| event_now  | 2014-07-01 04:26:53 | 
| event_now  | 2014-07-01 04:27:53 | 
| event_now  | 2014-07-01 04:28:53 | 
+------------+---------------------+ 

3.3.3 创建事件3(每秒钟启动事件)

CREATE event event_now  
ON SCHEDULE  
EVERY 1 SECOND
DO INSERT INTO event_test VALUES(1); 

3.3.4 创建事件4(每秒钟调用存储过程)

CREATE DEFINER=`root`@`localhost` EVENT `eventUpdateStatus` 
ON SCHEDULE EVERY 1 SECOND 
STARTS ‘2017-11-21 00:12:44‘ 
ON COMPLETION PRESERVE 
ENABLE 
DO call updateStatus()

3.4 注意:
默认创建事件存储在当前库中,也可显示指定事件创建在哪个库中
通过show events只能查看当前库中创建的事件
事件执行完即释放,如立即执行事件,执行完后,事件便自动删除,多次调用事件或等待执行事件可以查看到。
如果两个事件需要在同一时刻调用,mysql会确定调用他们的顺序,如果要指定顺序,需要确保一个事件至少在另一个事件1秒后执行
对于递归调度的事件,结束日期不能在开始日期之前。
select可以包含在一个事件中,然而他的结果消失了,就好像没执行过。

4 查看事件
查看当前所在库的事件
mysql> show events;
查看所有事件
mysql> select * from mysql.event;

历史文章:
JAVA微信企业付款到零钱(十分钟搞定)
微信授权获取用户openId的方法和步骤
一个微信号同时支持多个环境网页授权
微信两种签名算法MD5和HMAC-SHA256

mysql定时任务(event事件)

标签:led   scheduler   增加   长度   ant   最大   另一个   ams   start   

人气教程排行