mysql-常用組件之定時(shí)器

定時(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 ;
  • 注意
  1. 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ǔ)句浸须。
  2. 設(shè)置定時(shí)器事件的生效與否語(yǔ)句:
ALTER EVENT event_minute DISABLE;  # 關(guān)閉事件
ALTER EVENT event_minute ENABLE;   # 啟用事件
  1. 最后需要周期性執(zhí)行的語(yǔ)句也可用存儲(chǔ)過(guò)程來(lái)代替惨寿,使用 DO CALL procedure() 語(yǔ)句來(lái)代替。

舉例

  1. 從現(xiàn)在開(kāi)始每隔九天定時(shí)執(zhí)行
ON SCHEDULE EVERY 9 DAY STARTS NOW() 删窒;
  1. 每個(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);
  1. 每個(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);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末裂垦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子肌索,更是在濱河造成了極大的恐慌蕉拢,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件诚亚,死亡現(xiàn)場(chǎng)離奇詭異晕换,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)站宗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)闸准,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人份乒,你說(shuō)我怎么就攤上這事恕汇。” “怎么了或辖?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵瘾英,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我颂暇,道長(zhǎng)缺谴,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任耳鸯,我火速辦了婚禮湿蛔,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘县爬。我一直安慰自己阳啥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布财喳。 她就那樣靜靜地躺著察迟,像睡著了一般斩狱。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上扎瓶,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天所踊,我揣著相機(jī)與錄音,去河邊找鬼概荷。 笑死秕岛,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的误证。 我是一名探鬼主播继薛,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼雷厂!你這毒婦竟也來(lái)了惋增?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤改鲫,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后林束,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體像棘,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年壶冒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了缕题。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡胖腾,死狀恐怖烟零,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情咸作,我是刑警寧澤锨阿,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布,位于F島的核電站记罚,受9級(jí)特大地震影響墅诡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桐智,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一末早、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧说庭,春花似錦然磷、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春痪欲,著一層夾襖步出監(jiān)牢的瞬間悦穿,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工业踢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留栗柒,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓知举,卻偏偏與公主長(zhǎng)得像瞬沦,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子雇锡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355