MySQL創(chuàng)建定時任務
定時任務是老生常談了,因為我們總是需要定時修改特定的數(shù)據(jù)。
實現(xiàn)它的方法肯定不止一種,但我在相當長一段時間里都是用程序編碼去做的,今天突然想到“為什么一定要采用調(diào)用的方式?”,用數(shù)據(jù)庫自身的能力去實現(xiàn)不是更好么?
通過了解,mysql的事件機制可以完成定時任務,其原理是在指定的時間調(diào)用指定的存儲過程。現(xiàn)在很簡單了不是?開搞。
首先,我們需要一個存儲過程,雖然很簡單,但考慮到入門童鞋,我還是貼出一個例子:
delimiter $$; create procedure del_car_viol() begin delete from car_viol where `create` < date_sub(curdate(), interval 1 day); end $$; delimiter;
這一段代碼中創(chuàng)建了一個存儲過程,它可以刪除時間小于昨天的數(shù)據(jù)(表明字段名請無視)。
接下來就是創(chuàng)建一個事件,讓事件按照某種規(guī)則去調(diào)用存儲過程,這樣就可以實現(xiàn)定時操作的功能。
代碼如下:
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ào)用之前寫好的存儲過程。
代碼中的 1 day 代表一天一次,你也可以替換成 2 year(2年一次)。
事件創(chuàng)建好以后就會立刻執(zhí)行一次,并且一般是默認開啟的。
如果你想控制某個事件的運行狀態(tài),可以這樣:
/*開啟事件*/ alter event 事件名 on completion preserve enable; /*關閉事件*/ alter event 事件名 on completion preserve disable;
如果你不知道你的mysql有沒有開啟時間功能的支持,可以通過以下語句查詢:
/*查看事件功能是否開啟*/ show variables like 'event_scheduler';
查詢表中value為 off 代表關,on 代表開。如果想開啟事件功能,執(zhí)行以下語句:
/*開啟事件功能*/ set global event_scheduler = on;
需要注意的是,event機制是mysql5.1版本開始引入的,這意味著版本低于5.1的可能無法使用。
到此這篇關于MySQL創(chuàng)建定時任務的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
linux mysql5.5升級至mysql5.7的步驟與踩到的坑
這篇文章主要介紹了linux mysql5.5升級至mysql5.7的詳細步驟,后面腳本之家小編為大家整理了多個補充,大家可以參考一下2021-01-01MySQL8.0.28數(shù)據(jù)庫安裝和主從配置說明
這篇文章主要介紹了MySQL8.0.28數(shù)據(jù)庫安裝和主從配置說明,具有很好的參考價值,希望杜大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12mysql unique option prefix myisam_recover instead of myisam-
Using unique option prefix myisam_recover instead of myisam-recover-options is deprecated and will be removed in a future release. Please use the full name instead2016-05-05MySQL中KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的區(qū)別
本文給大家分享的是mysql索引中的KEY、PRIMARY KEY、UNIQUE KEY、INDEX 的區(qū)別,即主鍵索引,唯一索引和普通索引的區(qū)別,希望大家能夠喜歡2017-07-07IDEA連接mysql又報錯!Server returns invalid timezone. Go to tab an
這篇文章主要介紹了IDEA連接mysql又報錯!Server returns invalid timezone. Go to 'Advanced' tab and set 'serverTimezone' prope問題,本文通過圖文并茂的形式給大家介紹的非常詳細,需要的朋友可以參考下2020-05-05