自 MySQL5.1.6起,增长了一个很是有特点的功能–事件调度器(Event Scheduler),能够用作定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操做系统的计划任务来执行的工做。更值得 一提的是MySQL的事件调度器能够精确到每秒钟执行一个任务,而操做系统的计划任务(如:Linux下的CRON或Windows下的任务计划)只能精 确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就很是适合。
事件调度器有时也可称为临时触发器(temporal triggers),由于事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。mysql
开启事件
在使用这个功能以前必须确保event_scheduler已开启,可执行sql
SET GLOBAL event_scheduler = 1;
---或咱们能够在配置my.cnf文件 中加上 event_scheduler = 1
或
spa
SET GLOBAL event_scheduler = ON;
来开启,也能够直接在启动命令加上“--event_scheduler=1”,例如:
mysqld ... --event_scheduler=1
要查看当前是否已开启事件调度器,可执行以下SQL:
操作系统
SHOW VARIABLES LIKE 'event_scheduler';
或
code
SELECT @@event_scheduler;
或 orm
SHOW PROCESSLIST;
建立事件事件
CREATE EVENT [IF NOT EXISTS] event_name ON SCHEDULE schedule [ON COMPLETION [NOT] PRESERVE] [ENABLE | DISABLE] [COMMENT 'comment'] DO sql_statement; schedule: AT timestamp [+ INTERVAL interval] | EVERY interval [STARTS timestamp] [ENDS timestamp] interval: quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE | WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
其中,
event_name:定时器名,最大长度64个字符,若未指定,则默认为当前的MySQL用户名(不区分大小写);it
schedule:限定执行时间;event
ON COMPLETION [NOT] PRESERVE:表示是否须要循环复用这个Event;class
sql_statement:要执行的SQL语句(也能够使用存储过程代替传统的SQL语句);
comment:对该时间调度器的一个注释,最大长度64个字符;
关闭事件
ALTER EVENT event_name ON COMPLETION PRESERVE DISABLE;
开启事件
ALTER EVENT event_name ON COMPLETION PRESERVE ENABLE;
删除事件
DROP EVENT [IF EXISTS] event_name
范例
天天凌晨1点开始执行数据更新:
CREATE EVENT [IF NOT EXISTS] E_testEvent_1 ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 1 HOUR) ON COMPLETION PRESERVE ENABLE DO UPDATE _T_test SET col= 2 where ValidityDate < now();
每个月第一天凌晨1点开始执行数据更新(使用存储过程):
CREATE EVENT E_testEvent_2 ON SCHEDULE EVERY 1 MONTH STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR) ON COMPLETION PRESERVE ENABLE DO BEGIN CALL P_testProcedureName(); END
每季度第一天凌晨1点开始执行数据更新:
CREATE EVENT E_testEvent_3 ON SCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR) ON COMPLETION PRESERVE ENABLE DO UPDATE _T_test SET col= 2 where ValidityDate < now();
2007年7月20日12点整清空test表
CREATE EVENT e_test ONSCHEDULE AT TIMESTAMP '2007-07-20 12:00:00' DO TRUNCATETABLE test.aaa;