MySQL定時事件

自 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;
相關文章
相關標籤/搜索