排程 - Event
MySQL事件(Events)是一種用於安排和自動執行指定任務或SQL語句的機制。它類似於作業系統上的計劃任務(cron jobs)或任何其他自動化工具,但在MySQL中實現。
Create Event
DELIMITER //
CREATE EVENT event_name
ON SCHEDULE schedule
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
DO
BEGIN
-- 執行的SQL語句或程式碼
END;
//
DELIMITER ;
event_name
:事件的名稱,應該是唯一的。schedule
:事件的排程設定,包括頻率和開始時間。ON COMPLETION [NOT] PRESERVE
:選擇是否在事件執行完成後保留事件。PRESERVE
表示保留,否則事件將被刪除。ENABLE | DISABLE
:您可以選擇啟用或禁用事件。默認情況下,事件是啟用的。DO
:事件的執行內容,包括要執行的SQL語句或程式碼。
排程設定
schedule
部分是事件的排程設定,可以使用以下選項:
EVERY interval
:指定事件的執行頻率,interval
可以是INTERVAL
運算式,例如EVERY 1 DAY
表示每天執行一次。STARTS start_time
:指定事件的開始時間,可以是日期和時間的格式。事件將在這個時間之後開始執行。ENDS end_time
:可選,指定事件的結束時間。事件將在這個時間之前停止執行。
範例
每天早上7點開始都會執行一次,並且在執行完成後保留:
DELIMITER //
CREATE EVENT my_daily_event
ON SCHEDULE EVERY 1 DAY
STARTS TIMESTAMP(CURRENT_DATE, '07:00:00') -- 每天早上7點開始執行
ON COMPLETION PRESERVE
DO
BEGIN
-- 執行您的SQL語句或程式碼
END;
//
DELIMITER ;
管理事件
要查看現有事件,可以使用以下SQL語句:
SHOW EVENTS;
要啟用或禁用事件,可以使用以下語句:
ALTER EVENT event_name ENABLE;
ALTER EVENT event_name DISABLE;
要刪除事件,可以使用以下語句:
DROP EVENT event_name;
請注意,執行事件需要相應的權限。通常,只有具有事件權限的用戶才能創建、修改或刪除事件。
總之,MySQL Event 是一種強大的自動化工具,可用於處理定期執行的任務和簡化數據庫管理。請確保謹慎設計和設置事件,以確保其正確性和安全性。
根據前面章節,針對分區增加排程機制,讓其真正做到全自動分區作業
DELIMITER ||
-- 如果事件已經存在,就刪除名為`auto_part_event`的事件。這是為了確保不重複創建同一事件。
DROP EVENT IF EXISTS `auto_part_event`;
-- 創建一個事件,如果名稱為`auto_part_event`的事件不存在的話。
CREATE EVENT IF NOT EXISTS `auto_part_event`
-- 定義事件的執行計劃。在這裡,它被設置為每天執行一次。
ON SCHEDULE EVERY 1 MONTH
-- 定義事件的起始時間,表示從這個日期和時間開始執行事件。這個事件只有一個起始時間。
-- 每月1號凌晨3點開始執行
STARTS TIMESTAMP(DATE_FORMAT(NOW(), '%Y-%m-01 03:00:00'))
-- 設置事件在到期後是否應保留。使用PRESERVE表示事件在到期後不應自動刪除。
ON COMPLETION PRESERVE
-- 啟用事件,使其能夠執行。
ENABLE
-- 添加對事件的註解,用於描述事件的目的或功能。
COMMENT 'event_auto_partition'
-- 開始事件的執行內容區塊。
DO BEGIN
-- 在內容區塊中,調用存儲過程auto_part並傳遞特定參數,以管理表t_big_data_practise的分區。
call auto_part('local_test', 't_big_data_practise', (SELECT DATE(MIN(`create_date`)) FROM t_big_data_practise), 1, 3);
-- 結束內容區塊,並恢復分隔符。
END||
DELIMITER ;
具體說明如下:
ON SCHEDULE EVERY 1 MONTH
:這部分設定了事件的執行頻率,每個月執行一次。STARTS TIMESTAMP(DATE_FORMAT(NOW(), '%Y-%m-01 03:00:00'))
:這部分設定了事件的開始時間。我們使用NOW()
函數獲取當前日期和時間,然後使用DATE_FORMAT
函數將其調整為每月的1號凌晨3點。這確保了事件在每月1號凌晨3點開始執行。DO BEGIN
和END||
:這是事件的執行內容區塊。在這個區塊中,我們調用了存儲過程auto_part
,並傳遞了特定的參數,以管理表t_big_data_practise
的分區。
該事件的目的是自動化管理表t_big_data_practise
的分區。該事件每個月執行一次,不會自動刪除,確保了數據表的分區策略保持有效。
Last updated