mysql 定時任務

來源:互聯網
上載者:User

標籤:

mysql 5.1以上支援定時任務。

 

SHOW VARIABLES LIKE ‘event_scheduler‘;   檢查是否已開啟該功能

 

開啟計劃任務功能:

SET GLOBAL event_scheduler = 1;
或SET GLOBAL event_scheduler = ON;

或者

my.ini or my.cnf 中的
[mysqld]
添加 event_scheduler=ON

 

先來看一下它的文法:

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}

#單次計劃任務: AT 時戳 
#重複的計劃任務 EVERY 時間(單位)的數量 時間單位 [STARTS 時戳][ENDS 時戳] 
在兩種計劃任務中,時戳可以是任意的TIMESTAMP 和DATETIME 資料類型,要求提供的是將來的時間(大於CURRENT_TIMESTAMP),而且小於Unix時間的最後時間(等於或小於‘2037-12-31 23:59:59‘) 
時間單位是關鍵詞:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND 
3.[ON COMPLETION [NOT] PRESERVE] COMPLETION 當單次計劃任務執行完畢後或當重複性的計劃任務執行到了ENDS階段。而聲明PRESERVE的作用是使事件在執行完畢後不會被Drop掉 
4.[ENABLE|DESABLE] ENABLE  開啟事件 DESABLE 關閉事件 
5.COMMENT 注釋 
6.DO sql_statement 執行的sql語句

USE test;
CREATE TABLE aaa (timeline TIMESTAMP);
CREATE EVENT e_test_insert
ON SCHEDULE EVERY 1 SECOND 
DO INSERT INTO test.aaa VALUES (CURRENT_TIMESTAMP);
等待3秒鐘後,再執行查詢看看:

mysql> SELECT * FROM aaa;
+---------------------+ 
| timeline            | 
+---------------------+ 
| 2007-07-18 20:44:26 | 
| 2007-07-18 20:44:27 | 
| 2007-07-18 20:44:28 | 
+---------------------+
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;
4) 每天定時清空test表:

CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
DO TRUNCATE TABLE test.aaa;
5) 5天后開啟每天定時清空test表:

CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
DO TRUNCATE TABLE test.aaa;
6) 每天定時清空test表,5天后停止執行:

CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAY
DO TRUNCATE TABLE test.aaa;
7) 5天后開啟每天定時清空test表,一個月後停止執行:

CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTH
DO TRUNCATE TABLE test.aaa;
[ON COMPLETION [NOT] PRESERVE]可以設定這個事件是執行一次還是持久執行,預設為NOT PRESERVE。
8) 每天定時清空test表(只執行一次,任務完成後就終止該事件):

CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
ON COMPLETION NOT PRESERVE
DO TRUNCATE TABLE test.aaa;
[ENABLE | DISABLE]可是設定該事件建立後狀態是否開啟或關閉,預設為ENABLE。
[COMMENT ‘comment’]可以給該事件加上注釋。

三、修改事件(ALTER EVENT)
ALTER EVENT event_name
  [ON SCHEDULE schedule]
  [RENAME TO new_event_name]
  [ON COMPLETION [NOT] PRESERVE]
  [COMMENT ‘comment‘]
  [ENABLE | DISABLE]
  [DO sql_statement]
1) 臨時關閉事件

ALTER EVENT e_test DISABLE;
2) 開啟事件

ALTER EVENT e_test ENABLE;
3) 將每天清空test表改為5天清空一次:

ALTER EVENT e_test
ON SCHEDULE EVERY 5 DAY;
四、刪除事件(DROP EVENT)
語 法很簡單,如下所示:

DROP EVENT [IF EXISTS] event_name
例如刪除前面建立的e_test事件

DROP EVENT e_test;
當然前提是這個事件存在,否則會產生ERROR 1513 (HY000): Unknown event錯誤,因此最好加上IF EXISTS

DROP EVENT IF EXISTS e_test;

 create event test
ON SCHEDULE AT ‘2007-09-01 12:00:00‘ + INTERVAL 1 DAY
on completion not preserve 
do insert into yyy values(‘hhh‘,‘uuu‘);

解釋:從2007-09-01開始,每天對錶yyy在12:00:00進行一個插入操作。而且只執行一次(on completion not preserve )

我的計劃任務為:

create event sysplan
ON SCHEDULE AT ‘2010-05-22 23:00:00‘ + INTERVAL 1 DAY
on completion not preserve 
do truncate table bjproj.ae_tmp;

 

mysql 定時任務

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.