文章出處

代碼例子:
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 語句。這可以是一個簡單的語句,如 SELECTINSERT,或它可以是一個用 BEGINEND 寫的復合語句。復合語句可以包含聲明循環和其它控制結構語句。

提示:要自定義編輯器的視圖并查看更多 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。(+INTERVALEVERY 不能同時使用。)

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 區間由兩部份組成,數量和時間單位*。
*YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND

 

 來源:http://www.navicat.com.cn/manual/online_manual/cn/navicat/win_manual/EventsMySQL.html

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()