代碼例子:
CREATE EVENT `course_listener` ON SCHEDULE EVERY 1 DAY STARTS '2012-07-18 00:00:00' ON COMPLETION PRESERVE ENABLE DO UPDATE `om_courselist` SET `status`=6 WHERE `status`=5 AND `closetime`<CURRENT_TIMESTAMP();
可以用navicat創建事件,更快捷:
Navicat創建和設計MySQL事件
1.開啟定時器 0:off 1:on
SET GLOBAL event_scheduler = 1;
2.在navicat左側選擇一個數據庫,單擊“時間”-“創建事件”,彈出一個窗口。
在定義選項輸入SQL語句,以BEGIN開頭,以END結尾。
如果是在本地運行,Definer為root@localhost。
3.計劃任務,每隔一段時間就有固定需求的操作,如創建表,刪除數據等操作。
3-1. AT 時間戳,用來完成單次的計劃任務。
3-2. EVERY 時間(單位)的數量時間單位[STARTS 時間戳] [ENDS時間戳],用來完成重復的計劃任務。時間單位較多,按需選擇。
在兩種計劃任務中,時間戳可以是任意的TIMESTAMP 和DATETIME 數據類型,時間戳需要大于當前時間。
最后保存就OK了
附上mysql事件的語法:
MySQL 或 MariaDB 事件語法
MySQL 事件計劃是在 MySQL 5.1.6 添加。MySQL 事件是按計劃運行工作。因此,我們有時稱它們為計劃事件。當你創建一個事件時,你是創建一個有名的數據庫對象,包含在一個或多個規律區間運行一個或多個 SQL 語句,并在特定的日期時間開始及結束。從概念上,這是類似 Windows 任務計劃程序的概念。點擊 來打開 事件 的對象列表。
定義
定義包括一個有效的 SQL 語句。這可以是一個簡單的語句,如 SELECT 或 INSERT,或它可以是一個用 BEGIN 和 END 寫的復合語句。復合語句可以包含聲明循環和其它控制結構語句。
提示:要自定義編輯器的視圖并查看更多 sql 編輯功能,請看編輯器高級功能。
定義者
指定當在事件運行時檢查訪問權限要使用的用戶帳號。默認定義者值是運行 CREATE EVENT 語句的的用戶。(這是和
DEFINER = CURRENT_USER 相同。)如果給予一個用戶值,它應該是一個 'user_name'@'host_name' 格式的
MySQL 帳號(使用在 GRANT 語句相同的格式)。user_name 及 host_name 值都是必須的。
狀態
你可以創建一個事件但可以用 DISABLE 關鍵字保持不激活。或者,你可以用 ENABLE 來出明確默認狀態,這是激活。
ON COMPLETION
正常情況下,一旦事件已過期,它將立即刪除。你可以通過指定 ON COMPLETION PRESERVE 來重寫此性能。使用 ON COMPLETION NOT PRESERVE 只是使默認非持久性的性能明確。
計劃
AT
AT timestamp 用于一次性事件。它指定該事件只運行一次于 timestamp 的日期和時間,它必須同時包含日期和時間,或必須是一個解析為 datetime 值的表達式。使用 +INTERVAL 來創建一個事件,它發生在與當前日期和時間有關的將來某個時候。
EVERY
在定期間隔重復的行動,你可以用一個 EVERY 子句之后是一個 interval。(+INTERVAL 與 EVERY 不能同時使用。)
STARTS
EVERY 子句還可能包含一個非必須的 STARTS 子句。STARTS 之后是一個 timestamp 值表示行動應該何時開始重復,也可以用 +INTERVAL 間隔以指定「由現在開始」的時間量。
例如:EVERY 3 MONTH STARTS CURRENT_TIMESTAMP + 1 WEEK 的意思是「每 3 個月,從現在起一周后開始」。
ENDS
EVERY 子句還可包含一個非必須的 ENDS 子句。ENDS 關鍵字之后是一個 timestamp 值告訴 MySQL 何時停止重復事件。你也可以用 +INTERVAL 間隔與 ENDS 一起。
例如:EVERY 12 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 30 MINUTE ENDS CURRENT_TIMESTAMP + INTERVAL 4 WEEK 相當于「每十二個小時,從現在起三十分鐘后開始,并于現在起四個星期后結束」。
P.S. | timestamp 必須在未來的 - 你不能安排一個事件發生在過去。 |
interval 區間由兩部份組成,數量和時間單位*。 |
來源:http://www.navicat.com.cn/manual/online_manual/cn/navicat/win_manual/EventsMySQL.html
文章列表
留言列表