mysql 定時指令碼(event),類似oracle的job

abin1703發表於2016-05-10
1、開啟mysql event(事件)

mysql> show variables like '%event_sch%';

+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| event_scheduler | OFF   |
+-----------------+-------+
1 row in set (0.00 sec)

開啟event(事件)

vi /etc/my.cnf
[mysql]
event_scheduler=on

重啟資料庫

service mysql restart

mysql> show variables like '%event_sch%';
+-----------------+-------+
| Variable_name   | Value |
+-----------------+-------+
| event_scheduler | ON    |
+-----------------+-------+
1 row in set (0.00 sec)

2、建立event

DELIMITER $$
CREATE event event_p2
ON SCHEDULE
EVERY 5 MINUTE
STARTS NOW()
DO
BEGIN
CALL p2(160105);
END$$
DELIMITER ;


3、檢視event

mysql> show events\G;
*************************** 1. row ***************************
                  Db: report
                Name: event_p2
             Definer: root@localhost
           Time zone: SYSTEM
                Type: RECURRING
          Execute at: NULL
      Interval value: 1
      Interval field: MINUTE
              Starts: 2016-05-10 20:09:50
                Ends: NULL
              Status: ENABLED
          Originator: 1
character_set_client: utf8
collation_connection: utf8_general_ci
  Database Collation: utf8_general_ci
1 row in set (0.00 sec)

  1. CREATE EVENT [IF NOT EXISTS] event_name  
  2.     ON SCHEDULE schedule  
  3.     [ON COMPLETION [NOT] PRESERVE]  
  4.     [ENABLE | DISABLE]  
  5.     [COMMENT 'comment']  
  6.     DO sql_statement;  
  7. schedule:  
  8.     AT timestamp [+ INTERVAL interval]  
  9.   | EVERY interval [STARTS timestamp] [ENDS timestamp]  
  10. interval:  
  11.     quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |  
  12.               WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |  
  13.               DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}  


其中,
event_name:定時器名,最大長度64個字元,若未指定,則預設為當前的MySQL使用者名稱(不區分大小寫);

schedule:限定執行時間;

ON COMPLETION [NOT] PRESERVE:表示是否需要迴圈複用這個Event;

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  


【注意】
:要使用定時器,MySQL的常量GLOBAL event_scheduler必須為on或者是1.


【範例】

1. 每天凌晨1點開始執行資料更新:

  1. CREATE EVENT [IF NOT EXISTS] E_testEvent_1   
  2.     ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 1 HOUR)   
  3.     ON COMPLETION PRESERVE ENABLE   
  4.     DO  
  5.     BEGIN
  6.        call p2();
  7.     end ;


2. 每月第一天凌晨1點開始執行資料更新(使用儲存過程):

  1. CREATE EVENT E_testEvent_2   
  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)  
  3.     ON COMPLETION PRESERVE ENABLE  
  4.     DO  
  5.     BEGIN  
  6.         CALL p2();
  7.     END  


3. 每季度第一天凌晨1點開始執行資料更新:

  1. CREATE EVENT E_testEvent_3    
  2.     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)  
  3.     ON COMPLETION PRESERVE ENABLE  
  4.     DO  
  5.         UPDATE _T_test SET col= 2 ;




來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30345407/viewspace-2097000/,如需轉載,請註明出處,否則將追究法律責任。

相關文章