溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL如何創建定時任務

發布時間:2022-01-21 11:50:06 來源:億速云 閱讀:159 作者:小新 欄目:開發技術

這篇文章主要介紹MySQL如何創建定時任務,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

定時任務是老生常談了,因為我們總是需要定時修改特定的數據。

實現它的方法肯定不止一種,但我在相當長一段時間里都是用程序編碼去做的,今天突然想到“為什么一定要采用調用的方式?”,用數據庫自身的能力去實現不是更好么?

通過了解,mysql的事件機制可以完成定時任務,其原理是在指定的時間調用指定的存儲過程?,F在很簡單了不是?開搞。

首先,我們需要一個存儲過程,雖然很簡單,但考慮到入門童鞋,我還是貼出一個例子:

delimiter $$;
create procedure del_car_viol()
begin
    delete from car_viol where `create` < date_sub(curdate(), interval 1 day);
end
$$;
delimiter;

這一段代碼中創建了一個存儲過程,它可以刪除時間小于昨天的數據(表明字段名請無視)。

接下來就是創建一個事件,讓事件按照某種規則去調用存儲過程,這樣就可以實現定時操作的功能。

代碼如下:

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();

上面的代碼創建的事件,它可以從2017年9月2日零點開始每隔一天自動調用之前寫好的存儲過程。

代碼中的 1 day 代表一天一次,你也可以替換成 2 year(2年一次)。

事件創建好以后就會立刻執行一次,并且一般是默認開啟的。

如果你想控制某個事件的運行狀態,可以這樣:

/*開啟事件*/
alter event 事件名 on completion preserve enable; 
/*關閉事件*/
alter event 事件名 on completion preserve disable;

如果你不知道你的mysql有沒有開啟時間功能的支持,可以通過以下語句查詢:

/*查看事件功能是否開啟*/
show variables like 'event_scheduler';

查詢表中value為 off 代表關,on 代表開。如果想開啟事件功能,執行以下語句:

/*開啟事件功能*/
set global event_scheduler = on;

需要注意的是,event機制是mysql5.1版本開始引入的,這意味著版本低于5.1的可能無法使用。

以上是“MySQL如何創建定時任務”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女