MySQL5.1.x版本中引入了一项新特性EVENT,顾名思义就是事件、定时任务机制,在指定的时间单元内执行特定的任务,因此今后一些对数据定时性操作不再依赖外部程序,而直接使用数据库本身提供的功能。
要查看当前是否已开启事件调度器,可执行如下SQL:
SHOW VARIABLES LIKE 'event_scheduler';
或
SELECT @@event_scheduler;
或
SHOW PROCESSLIST;
若显示:
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| event_scheduler | OFF |
+-----------------+-------+
则可执行
SET GLOBAL event_scheduler = 1;
或
SET GLOBAL event_scheduler = ON;
来开启,也可以直接在启动命令加上“–event_scheduler=1”,例如:
mysqld ... --event_scheduler=1
或在my.ini 中的
[mysqld]
添加 event_scheduler=ON
创建定时任务
语法:
CREATE EVENT
[IF NOT EXISTS] ---------------------------------------------*标注1
event_name -----------------------------------------------------*标注2
ON SCHEDULE schedule ------------------------------------*标注3
[ON COMPLETION [NOT] PRESERVE] -----------------*标注4
[ENABLE | DISABLE] ----------------------------------------*标注5
[COMMENT 'comment'] --------------------------------------*标注6
DO sql_statement -----------------------------------------------*标注7
说明:
标注1:判断是否存在
标注2:定时任务名称
标注3:ON SCHEDULE
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,不建议使用这些不标准的时间单位。
标注4: [ON COMPLETION [NOT] PRESERVE]
ON COMPLETION参数表示"当这个事件不会再发生的时候",即当单次计划任务执行完毕后或当重复性的计划任务执行到了ENDS阶段。而PRESERVE的作用是使事件在执行完毕后不会被Drop掉,建议使用该参数,以便于查看EVENT具体信息。
标注5:[ENABLE | DISABLE]
参数Enable和Disable表示设定事件的状态。Enable表示系统将执行这个事件。Disable表示系统不执行该事件。
标注6:说明内容
标注7:要执行的语句。
例1:每天凌晨一点执行
CREATE EVENT `event_call_inproc`
ON SCHEDULE EVERY 1 DAY STARTS '2013-09-12 01:00:00'
ON COMPLETION PRESERVE ENABLE
DO
begin
call ty.inproc();
end
例2:5天后清空test表
CREATE EVENT e_test
ON
SCHEDULE
AT
CURRENT_TIMESTAMP
+ INTERVAL 5
DAY
DO
TRUNCATE
TABLE
test.aaa;
例3:2007年7月20日12点整清空test表
CREATE
EVENT e_test
ON
SCHEDULE
AT
TIMESTAMP
'2007-07-20 12:00:00'
DO
TRUNCATE
TABLE
test.aaa;
常用的执行时间点如下:
-- 下一个月1号凌晨1点
SELECT DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR) ;
-- 第二天凌晨3点
SELECT date_add(date(curdate() + 1),interval 3 hour) ;
-- 下季度1号凌晨2点
SELECT DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR);
-- 下一年1月1号凌晨4点
SELECT DATE_ADD(DATE(CONCAT(YEAR(CURDATE()) + 1,'-',1,'-',1)),INTERVAL 4 HOUR);
开启定时任务
alter event e_test ON
COMPLETION PRESERVE DISABLE;
关闭定时任务
alter event e_test ON
COMPLETION PRESERVE ENABLE;
删除定时任务
DROP EVENT e_test;
或
DROP EVENT IF EXISTS e_test;
ALTER EVENT event_name
[ON SCHEDULE schedule]
[RENAME TO new_event_name]
[ON COMPLETION [NOT] PRESERVE]
[COMMENT 'comment']
[ENABLE | DISABLE]
[DO sql_statement]
ALTER EVENT e_test
ON SCHEDULE EVERY 5 DAY;
查看定时任务: