mysql事件機制 mysql事件機制 定時任務

2021-10-18 03:04:13 字數 1288 閱讀 9241

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

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

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

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

delimiter $$;

create procedure del_car_viol()

begin

delete from car_viol where `create` < date_sub(curdate(), interval 1 day);

enddelimiter;

這一段**中建立了乙個儲存過程,它可以刪除時間小於昨天的資料(表明欄位名請無視)。

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

**如下:

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

上面的**建立的事件,它可以從2023年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事件機制 mysql事件機制 定時任務

定時任務是老生常談了,因為我們總是需要定時修改特定的資料。實現它的方法肯定不止一種,但我在相當長一段時間裡都是用程式編碼去做的,今天突然想到 為什麼一定要採用呼叫的方式?用資料庫自身的能力去實現不是更好麼?通過了解,mysql的事件機制可以完成定時任務,其原理是在指定的時間呼叫指定的儲存過程。現在很...

mysql事件機制 定時任務

定時任務是老生常談了,因為我們總是需要定時修改特定的資料。實現它的方法肯定不止一種,但我在相當長一段時間裡都是用程式編碼去做的,今天突然想到 為什麼一定要採用呼叫的方式?用資料庫自身的能力去實現不是更好麼?通過了解,mysql的事件機制可以完成定時任務,其原理是在指定的時間呼叫指定的儲存過程。現在很...

mysql事務機制 Mysql事務機制

mysql事務是指將資料庫從一種一致性狀態轉到另一種一致性狀態 mysql事務具有acid特性 原子性 atomicity 事務中的所有操作,要麼全部執行,要麼都不執行 一致性 consistency 事務開始和結束後,資料庫的完整性不會被破壞 隔離性 isolation 事務之間互不影響。事務的隔...