自 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;