MySQL創(chuàng)建定時(shí)任務(wù)
定時(shí)任務(wù)是老生常談了,因?yàn)槲覀兛偸切枰〞r(shí)修改特定的數(shù)據(jù)。
實(shí)現(xiàn)它的方法肯定不止一種,但我在相當(dāng)長(zhǎng)一段時(shí)間里都是用程序編碼去做的,今天突然想到“為什么一定要采用調(diào)用的方式?”,用數(shù)據(jù)庫(kù)自身的能力去實(shí)現(xiàn)不是更好么?
通過(guò)了解,mysql的事件機(jī)制可以完成定時(shí)任務(wù),其原理是在指定的時(shí)間調(diào)用指定的存儲(chǔ)過(guò)程?,F(xiàn)在很簡(jiǎn)單了不是?開搞。
首先,我們需要一個(gè)存儲(chǔ)過(guò)程,雖然很簡(jiǎn)單,但考慮到入門童鞋,我還是貼出一個(gè)例子:
delimiter $$;
create procedure del_car_viol()
begin
delete from car_viol where `create` < date_sub(curdate(), interval 1 day);
end
$$;
delimiter;這一段代碼中創(chuàng)建了一個(gè)存儲(chǔ)過(guò)程,它可以刪除時(shí)間小于昨天的數(shù)據(jù)(表明字段名請(qǐng)無(wú)視)。
接下來(lái)就是創(chuàng)建一個(gè)事件,讓事件按照某種規(guī)則去調(diào)用存儲(chǔ)過(guò)程,這樣就可以實(shí)現(xiàn)定時(shí)操作的功能。
代碼如下:
create event `e_update_user_ticket` on schedule every 1 day starts '2017-09-02 00:00:00' on completion not preserve enable do call del_car_viol();
上面的代碼創(chuàng)建的事件,它可以從2017年9月2日零點(diǎn)開始每隔一天自動(dòng)調(diào)用之前寫好的存儲(chǔ)過(guò)程。
代碼中的 1 day 代表一天一次,你也可以替換成 2 year(2年一次)。
事件創(chuàng)建好以后就會(huì)立刻執(zhí)行一次,并且一般是默認(rèn)開啟的。
如果你想控制某個(gè)事件的運(yùn)行狀態(tài),可以這樣:
/*開啟事件*/ alter event 事件名 on completion preserve enable; /*關(guān)閉事件*/ alter event 事件名 on completion preserve disable;
如果你不知道你的mysql有沒(méi)有開啟時(shí)間功能的支持,可以通過(guò)以下語(yǔ)句查詢:
/*查看事件功能是否開啟*/ show variables like 'event_scheduler';
查詢表中value為 off 代表關(guān),on 代表開。如果想開啟事件功能,執(zhí)行以下語(yǔ)句:
/*開啟事件功能*/ set global event_scheduler = on;
需要注意的是,event機(jī)制是mysql5.1版本開始引入的,這意味著版本低于5.1的可能無(wú)法使用。
到此這篇關(guān)于MySQL創(chuàng)建定時(shí)任務(wù)的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL OOM 系列三 擺脫MySQL被Kill的厄運(yùn)
這篇文章主要介紹了MySQL OOM 系列三 擺脫MySQL被Kill的厄運(yùn) ,需要的朋友可以參考下2016-07-07
Mysql5.7.14安裝配置方法操作圖文教程(密碼問(wèn)題解決辦法)
本篇文章主要涉及mysql5.7.14用以往的安裝方法安裝存在的密碼登錄不上,密碼失效等問(wèn)題的解決辦法,需要的朋友參考下吧2017-01-01
MySQL中DATE_FORMATE函數(shù)使用時(shí)的注意點(diǎn)
這篇文章主要介紹了MySQL中DATE_FORMATE函數(shù)使用時(shí)的注意點(diǎn),主要是針對(duì)其內(nèi)置的字符集使用時(shí)需要轉(zhuǎn)換而進(jìn)行說(shuō)明,需要的朋友可以參考下2015-05-05
Mysql數(shù)據(jù)庫(kù)從5.6.28版本升到8.0.11版本部署項(xiàng)目時(shí)遇到的問(wèn)題及解決方法
這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)從5.6.28版本升到8.0.11版本過(guò)程中遇到的問(wèn)題及解決方法,解決辦法有三種,每種方法給大家介紹的都很詳細(xì),感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05
6G數(shù)據(jù)庫(kù)的導(dǎo)入 報(bào)各種錯(cuò)誤的解決辦法
今天看到一高人的mysql數(shù)據(jù)庫(kù)達(dá)到了6G左右,導(dǎo)入都是個(gè)問(wèn)題,上傳也挺麻煩的,這里特分享下,方便需要的朋友2013-01-01

