用MySQL創建定時任務


-- 查看有哪些定時計划
show events
-- 刪除名稱為risk的定時計划
DROP EVENT IF EXISTS risk;
-- 創建定時計划的例子,每天定時,自動將日期加1天
CREATE EVENT `risk_spider_crawl_param_update`
ON SCHEDULE EVERY 1 DAY STARTS '2020-03-13 01:30:00'
ON COMPLETION PRESERVE
ENABLE
DO
update risk_spiders_crawl_param set start_date=CURRENT_DATE, end_date = date(CURRENT_DATE + 1) ;

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

 

來自:http://mysql.zhizuobiao.com/mysql-18081600248/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM