mysql事件機制——定時任務

來源:互聯網
上載者:User

標籤:ticket   執行   開啟   var   並且   com   pre   highlight   $$   

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

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

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

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

 

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事件機制——定時任務

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.