定時(shí)器主要用于定時(shí)的執(zhí)行一次或者循環(huán)執(zhí)行一條sql乍迄,在實(shí)際場(chǎng)景上,例如士败,定期清理數(shù)據(jù)表闯两,定期導(dǎo)出日志文件等等場(chǎng)景。本次公司晚上維護(hù)系統(tǒng)谅将,需要定期掛維護(hù)頁(yè)漾狼,總結(jié)一下定時(shí)器的簡(jiǎn)單用法。
啟用定時(shí)器
MySQL event 功能默認(rèn)是關(guān)閉的饥臂,可以使用下面的語(yǔ)句來(lái)看 event 的狀態(tài)逊躁,如果是 OFF 或者 0,表示是關(guān)閉的隅熙。
- 檢查命令
SHOW VARIABLES LIKE 'event_scheduler';
-
定時(shí)器已經(jīng)開(kāi)啟的執(zhí)行結(jié)果:
開(kāi)啟成功示例.png
如果未開(kāi)啟定時(shí)器稽煤,執(zhí)行以下命令開(kāi)啟定時(shí)器:
SET GLOBAL event_scheduler = 1;
-
注意:雖然這里用
set global event_scheduler = on
語(yǔ)句開(kāi)啟了事件,但是每次重啟服務(wù)器或重啟 mysql 服務(wù)后猛们,事件會(huì)自動(dòng)關(guān)閉(event_scheduler=OFF)念脯,所以想讓事件一直保持開(kāi)啟,最好修改配置文件弯淘,讓 mysql 服務(wù)啟動(dòng)的時(shí)候開(kāi)啟時(shí)間绿店,只需要在my.cnf
配置文件的[mysqld]
部分加上event_scheduler=ON
即可:
設(shè)置定時(shí)器自啟動(dòng).png - 關(guān)閉定時(shí)器命令:
SET GLOBAL event_scheduler = 0;
創(chuàng)建定時(shí)器
創(chuàng)建定時(shí)器 SQL 模板:
DELIMITER $$
-- SET GLOBAL event_scheduler = ON$$ -- required for event to execute but not create
CREATE /*[DEFINER = { user | CURRENT_USER }]*/ EVENT `dbName`.`eventName` -- 事件名
ON SCHEDULE
/* uncomment the example below you want to use */
-- scheduleexample 1: run once 只執(zhí)行一次
-- AT 'YYYY-MM-DD HH:MM.SS'/CURRENT_TIMESTAMP { + INTERVAL 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...] }
-- scheduleexample 2: run at intervals forever after creation 創(chuàng)建完后周期性執(zhí)行
-- EVERY 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...]
-- scheduleexample 3: specified start time, end time and interval for execution 指定開(kāi)始和結(jié)束時(shí)間,并在期間內(nèi)周期性的執(zhí)行
/*EVERY 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...]
STARTS CURRENT_TIMESTAMP/'YYYY-MM-DD HH:MM.SS' { + INTERVAL 1[HOUR|MONTH|WEEK|DAY|MINUTE|...] }
ENDS CURRENT_TIMESTAMP/'YYYY-MM-DD HH:MM.SS' { + INTERVAL 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...] } */
/*[ON COMPLETION [NOT] PRESERVE] -- 時(shí)間完成后是否刪除事件
[ENABLE | DISABLE] -- 是否立即生效
[COMMENT 'comment']*/
DO
BEGIN
(sql_statements) -- 需要周期性執(zhí)行的 sql 語(yǔ)句
END$$
DELIMITER ;
- 注意:
-
DELIMITER $$
這個(gè)是將mysql中以 ; 結(jié)尾的規(guī)定修改為以 $$ 為語(yǔ)句結(jié)束符,因?yàn)榇鎯?chǔ)過(guò)程里可以有多條 sql 語(yǔ)句假勿,里面的 sql 語(yǔ)句都以 ; 結(jié)尾借嗽,如果回車(chē)了那么系統(tǒng)會(huì)當(dāng)做 sql 語(yǔ)句直接執(zhí)行了,我們希望的是先定義這一系列 sql 語(yǔ)句而先不執(zhí)行转培,所以要改下操作結(jié)束符恶导。當(dāng)然你在改后一定要改回來(lái),大家可以看到最后一行有對(duì)應(yīng)的修改回來(lái)的語(yǔ)句浸须。 - 設(shè)置定時(shí)器事件的生效與否語(yǔ)句:
ALTER EVENT event_minute DISABLE; # 關(guān)閉事件
ALTER EVENT event_minute ENABLE; # 啟用事件
- 最后需要周期性執(zhí)行的語(yǔ)句也可用存儲(chǔ)過(guò)程來(lái)代替惨寿,使用
DO CALL procedure()
語(yǔ)句來(lái)代替。
舉例
- 從現(xiàn)在開(kāi)始每隔九天定時(shí)執(zhí)行
ON SCHEDULE EVERY 9 DAY STARTS NOW() 删窒;
- 每個(gè)月的一號(hào)凌晨 1 點(diǎn)執(zhí)行
on schedule every 1 month starts date_add(date_add(date_sub(curdate(),interval day(curdate())-1 day),interval 1 month),interval 1 hour);
- 每個(gè)季度一號(hào)的凌晨1點(diǎn)執(zhí)行
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 1 hour);