mysql set timed task

Reprinted from: https://www.cnblogs.com/laowu-blog/p/5073665.html


Today, I encountered a task that needs to be executed regularly every day. This function is provided in the mysql database, which is just sorted and shared.

1. First check whether the scheduled task is enabled

1
2
3
4
5
6
查看event是否开启 : SHOW VARIABLES  LIKE  '%event_sche%' ;
将事件计划开启 :  SET  GLOBAL  event_scheduler = 1;
将事件计划关闭 :  SET  GLOBAL  event_scheduler = 0;
关闭事件任务 :  ALTER  EVENT eventName  ON  COMPLETION PRESERVE DISABLE;
开启事件任务 :  ALTER  EVENT eventName  ON  COMPLETION PRESERVE ENABLE;
查看事件任务 : SHOW EVENTS ;

2. Create a stored procedure

1
2
3
4
5
6
DELIMITER //
DROP  PROCEDURE  IF EXISTS p_test//
CREATE  PROCEDURE  p_test() 
BEGIN
INSERT  INTO  test( name , create_time)  values ( 'testName' , now());
END //

3. Set a timed task to call this stored procedure (execute every ten seconds from 1:00 on August 8, 2015)

1
2
3
4
5
6
7
8
DROP  EVENT IF EXISTS e_test//
CREATE  EVENT e_test
ON  SCHEDULE EVERY 10  second  STARTS  TIMESTAMP  '2015-08-08 01:00:00'
ON  COMPLETION PRESERVE
DO
BEGIN
CALL p_test();
END //

 

 

备注:在event事件中:ON SCHEDULE 计划任务,有两种设定计划任务的方式:
 
1. AT 时间戳,用来完成单次的计划任务。

2. EVERY 时间(单位)的数量时间单位[STARTS 时间戳] [ENDS时间戳],用来完成重复的计划任务。

在两种计划任务中,时间戳可以是任意的TIMESTAMP 和DATETIME 数据类型,时间戳需要大于当前时间。

在重复的计划任务中,时间(单位)的数量可以是任意非空(Not Null)的整数式,时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。

提示: 其他的时间单位也是合法的如:QUARTER, WEEK, YEAR_MONTH,DAY_HOUR,DAY_MINUTE,DAY_SECOND,HOUR_MINUTE,HOUR_SECOND, MINUTE_SECOND,不建议使用这些不标准的时间单位。

 [ON COMPLETION [NOT] PRESERVE]
 
ON COMPLETION参数表示"当这个事件不会再发生的时候",即当单次计划任务执行完毕后或当重复性的计划任务执行到了ENDS阶段。而PRESERVE的作用是使事件在执行完毕后不会被Drop掉,建议使用该参数,以便于查看EVENT具体信息。

Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=324384935&siteId=291194637