《Mysql應(yīng)用MySQL中的事件調(diào)度基礎(chǔ)學(xué)習(xí)教程》要點:
本文介紹了Mysql應(yīng)用MySQL中的事件調(diào)度基礎(chǔ)學(xué)習(xí)教程,希望對您有用。如果有疑問,可以聯(lián)系我們。
MYSQL必讀經(jīng)常需要有一些定時任務(wù)在MySQL表上執(zhí)行,例如統(tǒng)計、遷移、刪除無用數(shù)據(jù)等.之前的作法是利用Linux cron定時運行腳本,但是發(fā)現(xiàn)這樣的額外依賴有時并不方便,例如單機(jī)多實例部署時,就需要分別手動分別配置不同的cron任務(wù),需要額外配置相應(yīng)的用戶和權(quán)限;新環(huán)境部署時容易遺漏cron任務(wù)等.
MYSQL必讀MySQL提供了Event Scheduler,與Linux下的crontab類似,可以根據(jù)時間調(diào)度來運行任務(wù),運行一次或多次.
MYSQL必讀完整的Event Schduler創(chuàng)建語句如下:
MYSQL必讀
CREATE
[DEFINER = { user | CURRENT_USER }]
EVENT
[IF NOT EXISTS]
event_name
ON SCHEDULE schedule
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE | DISABLE ON SLAVE]
[COMMENT 'comment']
DO event_body;
schedule:
AT timestamp [+ INTERVAL interval] …
| EVERY interval
[STARTS timestamp [+ INTERVAL interval] …]
[ENDS timestamp [+ INTERVAL interval] …]
interval:
quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
MYSQL必讀一、調(diào)度Scheduler
MySQL中的調(diào)度可以是只運行一次,也可以指定時間間隔重復(fù)運行.其定義是在event定義的ON SCHEDULE子句中.該子句格式如下:
MYSQL必讀
ON SCHEDULE
AT timestamp [+ INTERVAL interval] …
| EVERY interval
[STARTS timestamp [+ INTERVAL interval] …]
[ENDS timestamp [+ INTERVAL interval] …]
MYSQL必讀其中,timestamp必須包括”年月日時分秒“,它參與表達(dá)式計算后,結(jié)果是datetime或者timestamp類型.
MYSQL必讀而時間間隔interval可以如下:
MYSQL必讀
<數(shù)字> {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
MYSQL必讀其含義很清晰,如YEAR 年;QUARTER 季度;YEAR_MONTH 年+月;MINUTE_SECOND 分鐘+秒.
MYSQL必讀補(bǔ)充:
MYSQL必讀YEAR | QUARTER | MONTH | YEAR_MONTH 后臺都轉(zhuǎn)換成MONTH,其他時間間隔都轉(zhuǎn)換成SECOND
ON SCHEDULE中的時間使用創(chuàng)建時本會話中的時區(qū)信息time_zone,這個時區(qū)默認(rèn)是服務(wù)端的全局time_zone,也可能后續(xù)手動更新掉.這些時間會轉(zhuǎn)化成UTC時間,存儲到mysql.event表中.
1.一次運行
AT直接指定時間,或者使用時間表達(dá)式計算得出確定的時間點.
MYSQL必讀示例:
MYSQL必讀AT '2006-02-10 23:59:00′?? 指定確切運行時間,本地時區(qū).
AT current_timestamp + INTERVAL '1:15′ MINUTE_SECOND? 指定1分15秒后運行.
2.多次運行
EVERY設(shè)置運行的時間間隔,這里不能再指定[+ INTERVAL interval].
MYSQL必讀指定STARTS、ENDS是可選的.
MYSQL必讀STARTS是指定重復(fù)運行的第一次是什么時候.不指定的情況下,會在事件創(chuàng)建時運行第一次,即等價于STARTS CURRENT_TIMESTAMP!
ENDS告知MySQL結(jié)束重復(fù)運行的時間點.不指定的情況下,MySQL會永遠(yuǎn)重復(fù)運行下去.
示例:
MYSQL必讀EVERY 5 WEEK? 每5周運行一次,創(chuàng)建時運行第一次.
EVERY 3 DAY STARTS '2013-12-4 09:10:00′? 從'2013-12-4 09:10:00′開始運行第一次,每隔3天運行一次.
EVERY 2 MONTH STARTS CURRENT_TIMESTAMP + INTERVAL 10 MINUTE ENDS '2014-12-31 23:59:59′ 10分鐘后開始到2014年底,每兩個月運行一次.
二、事件Event
1.啟用Event Scheduler功能
Event是由一個特定的Event Scheduler線程執(zhí)行的,運行過程中可以通過show full processlist查看其當(dāng)前狀態(tài)信息,如:
MYSQL必讀7384313???? event_scheduler???? localhost???? [NULL]???? Daemon???? 3???? Waiting on empty queue???? [NULL]
MYSQL必讀默認(rèn)事件調(diào)度Event Scheduler功能是未啟用的,需要配置全局參數(shù)event_scheduler,本參數(shù)可以動態(tài)設(shè)置,即時生效.
MYSQL必讀event_scheduler有如下三種取值:
MYSQL必讀OFF/0 關(guān)閉,默認(rèn)值.不運行Event Scheduler線程,也就無法進(jìn)行事件調(diào)度.設(shè)置為ON可以立即啟用.
ON/1 啟用.
DISABLED 禁用.同樣不運行Event Scheduler線程.只有在MySQL服務(wù)啟動時設(shè)置才有用.當(dāng)event_scheduler是ON或者OFF時,不能在運行時設(shè)置event_scheduler為DISABLED.如果啟動時配置了event-scheduler=DISABLED,則運行時就不能設(shè)置為ON/OFF.換句話中,可以在MySQL服務(wù)啟動時設(shè)置為DISABLED,然后完全禁用了event_scheduler,不能動態(tài)調(diào)整.
所以,要啟用event_scheduler,運行時執(zhí)行:
MYSQL必讀
set global event_scheduler=on
MYSQL必讀要隨MySQL服務(wù)一起啟用,則在/etc/my.cnf中添加
MYSQL必讀
[mysqld]
event-scheduler=on
MYSQL必讀2.創(chuàng)建事件的語法
MYSQL必讀
CREATE
[DEFINER = { user | CURRENT_USER }]
EVENT
[IF NOT EXISTS]
event_name
ON SCHEDULE schedule
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE | DISABLE ON SLAVE]
[COMMENT 'comment']
DO event_body;
schedule:
AT timestamp [+ INTERVAL interval] ...
| EVERY interval
[STARTS timestamp [+ INTERVAL interval] ...]
[ENDS timestamp [+ INTERVAL interval] ...]
interval:
quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
WEEK | SECOND | YEAR_MONTH | DAY_HOUR |
DAY_MINUTE |DAY_SECOND | HOUR_MINUTE |
HOUR_SECOND | MINUTE_SECOND}
MYSQL必讀參數(shù)詳細(xì)說明:
DEFINER: 定義事件執(zhí)行的時候檢查權(quán)限的用戶.
ON SCHEDULE schedule: 定義執(zhí)行的時間和時間間隔.
ON COMPLETION [NOT] PRESERVE: 定義事件是一次執(zhí)行還是永久執(zhí)行,默認(rèn)為一次執(zhí)行,即NOT PRESERVE.
ENABLE | DISABLE | DISABLE ON SLAVE: 定義事件創(chuàng)建以后是開啟還是關(guān)閉,以及在從上關(guān)閉.如果是從服務(wù)器自動同步主上的創(chuàng)建事件的語句的話,會自動加上DISABLE ON SLAVE.
COMMENT 'comment': 定義事件的注釋.
?
3.更改事件的語法
MYSQL必讀
ALTER
[DEFINER = { user | CURRENT_USER }]
EVENT event_name
[ON SCHEDULE schedule]
[ON COMPLETION [NOT] PRESERVE]
[RENAME TO new_event_name]
[ENABLE | DISABLE | DISABLE ON SLAVE]
[COMMENT 'comment']
[DO event_body]
MYSQL必讀4.刪除事件的語法
MYSQL必讀
DROP EVENT [IF EXISTS] event_name
MYSQL必讀5.Do子句
在Do子句中實現(xiàn)事件的具體邏輯,幾乎所有可以在存儲程序中運行的MySQL語句都可以在event中使用.
MYSQL必讀1)簡單SQL示例:
MYSQL必讀
CREATE EVENT e_hourly
ON SCHEDULE
EVERY 1 HOUR
COMMENT ‘Clears out sessions table each hour.'
DO
DELETE FROM site_activity.sessions;
MYSQL必讀2)復(fù)雜SQL示例:
MYSQL必讀
delimiter |
CREATE EVENT e
ON SCHEDULE
EVERY 5 SECOND
DO
BEGIN
DECLARE v INTEGER;
DECLARE CONTINUE HANDLER FOR SQLEXCEPTION BEGIN END;
SET v = 0;
WHILE v < 5 DO
INSERT INTO t1 VALUES (0);
UPDATE t2 SET s1 = s1 + 1;
SET v = v + 1;
END WHILE;
END |
delimiter ;
MYSQL必讀3)Do子句中SQL的限制
MYSQL必讀基本上Do中可以使用任何在存儲程序(Stored Routine)中允許的SQL語句,而存儲程序中有些限制,event還有些額外的限制.
MYSQL必讀Stored Routine中如下語句不允許:
MYSQL必讀支持動態(tài)SQL(PREPARE, EXECUTE, DEAALOCATE PREPARE)!但是PREPARE本身有些語句不允許執(zhí)行.
MYSQL必讀INSERT DELAYED不會生效
EVENT的限制:
MYSQL必讀如果Do子句中包含ALTER EVENT子句,雖然能夠創(chuàng)建,但是運行時會出錯.
不要在Do子句中使用SELECT或SHOW這樣僅僅是查詢的語句,因為其輸出無法從外部獲取到.可以使用SELECT … INTO 這樣的形式將查詢結(jié)果保存起來.
MYSQL必讀
5.查看EVENT
有如下方式可以查看event的信息:
MYSQL必讀
mysql.event
information_schema.events
show events
show create event
MYSQL必讀
三、event schedule其他注意點
MySQL保存了事件創(chuàng)建時的sql_mode作為其運行時的sql_mode;
如果在一個調(diào)度區(qū)間內(nèi)任務(wù)沒有處理完成,新的調(diào)度依然會生成,這樣就會出現(xiàn)同時又多個任務(wù)在運行的情況.如果要避免多個任務(wù)同時存在,可以使用GET_LOCK()函數(shù)或者行鎖、表鎖.
MYSQL必讀四、??? Mysql事件實戰(zhàn)
測試環(huán)境
創(chuàng)建一個用于測試的test表:
MYSQL必讀
CREATE TABLE `test` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`t1` datetime DEFAULT NULL,
`id2` int(11) NOT NULL DEFAULT '0',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=106 DEFAULT CHARSET=utf8
MYSQL必讀實戰(zhàn)1
?? 創(chuàng)建一個每隔3秒往test表中插入一條數(shù)據(jù)的事件,代碼如下:
MYSQL必讀
CREATE EVENT IF NOT EXISTS test ON SCHEDULE EVERY 3 SECOND
ON COMPLETION PRESERVE
DO INSERT INTO test(id,t1) VALUES('',NOW());
MYSQL必讀?? 創(chuàng)建一個10分鐘后清空test表數(shù)據(jù)的事件
MYSQL必讀
CREATE EVENT IF NOT EXISTS test
ON SCHEDULE
AT CURRENT_TIMESTAMP + INTERVAL 1 MINUTE
DO TRUNCATE TABLE test.aaa;
MYSQL必讀?? 創(chuàng)建一個在2012-08-23 00:00:00時刻清空test表數(shù)據(jù)的事件,代碼如下:
MYSQL必讀
CREATE EVENT IF NOT EXISTS test
ON SCHEDULE
AT TIMESTAMP '2012-08-23 00:00:00'
DO TRUNCATE TABLE test;
MYSQL必讀?? 創(chuàng)建一個從2012年8月22日21點45分開始到10分鐘后結(jié)束,運行每隔3秒往test表中插入一條數(shù)據(jù)的事件,代碼如下:
MYSQL必讀
CREATE EVENT IF NOT EXISTS test ON SCHEDULE EVERY 3 SECOND
STARTS '2012-08-22 21:49:00'
ENDS '2012-08-22 21:49:00'+ INTERVAL 10 MINUTE
ON COMPLETION PRESERVE
DO INSERT INTO test(id,t1) VALUES('',NOW());
MYSQL必讀?
?實戰(zhàn)2
通常的應(yīng)用場景是通過事件來定期的調(diào)用存儲過程,下面是一個簡單的示例:
創(chuàng)建一個讓test表的id2字段每行加基數(shù)2的存儲過程,存儲過程代碼如下:
MYSQL必讀
DROP PROCEDURE IF EXISTS test_add;
DELIMITER //
CREATE PROCEDURE test_add()
BEGIN
DECLARE 1_id INT DEFAULT 1;
DECLARE 1_id2 INT DEFAULT 0;
DECLARE error_status INT DEFAULT 0;
DECLARE datas CURSOR FOR SELECT id FROM test;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET error_status=1;
OPEN datas;
FETCH datas INTO 1_id;
REPEAT
SET 1_id2=1_id2+2;
UPDATE test SET id2=1_id2 WHERE id=1_id;
FETCH datas INTO 1_id;
UNTIL error_status
END REPEAT;
CLOSE datas;
END
//
MYSQL必讀事件設(shè)置2012-08-22 00:00:00時刻開始運行,每隔1調(diào)用一次存儲過程,40天后結(jié)束,代碼如下:
MYSQL必讀
CREATE EVENT test ON SCHEDULE EVERY 1 DAY
STARTS '2012-08-22 00:00:00'
ENDS '2012-08-22 00:00:00'+INTERVAL 40 DAY
ON COMPLETION PRESERVE DO
CALL test_add();
歡迎參與《Mysql應(yīng)用MySQL中的事件調(diào)度基礎(chǔ)學(xué)習(xí)教程》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/13048.html