好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > MySQL定時任務(EVENT事件)如何配置詳解

MySQL定時任務(EVENT事件)如何配置詳解

熱門標簽:地圖標注費用是多少 武漢網絡外呼系統服務商 啥是企業400電話辦理 南昌三維地圖標注 曲靖移動外呼系統公司 電話外呼系統改號 怎樣在地圖標注銷售區域 外呼系統打電話上限是多少 百應電話機器人優勢

一、事件(EVENT)是干什么的

  自MySQL5.1.6起,增加了一個非常有特色的功能 - 事件調度器(Event Scheduler),可以用做定時執行某些特定任務(例如:刪除記錄、數據統計報告、數據備份等等),來取代原先只能由操作系統的計劃任務來執行的工作。
  值得一提的是MySQL的事件調度器可以精確到每秒鐘執行一個任務,而操作系統的計劃任務(如:Linux的cron)只能精確到每分鐘執行一次。對于一些對數據實時性要求比較高的應用(例如:股票、賠率、比分等)就非常適合。

  事件有時也可以稱為臨時觸發器(temporal triggers),因為事件調度器是基于特定時間周期觸發來執行某些任務,而觸發器(Triggers)是基于某個表所產生的事件觸發的,區別也就在這里。

二、開啟“事件”功能

使用“事件”功能之前必須確保event_scheduler已開啟

1、查詢功能是否開啟:

-- 方法一
SELECT @@event_scheduler;
-- 方法二
SHOW VARIABLES LIKE 'event%';

顯示 “ON”說明功能已開啟;如下圖:

mysql> SELECT @@event_scheduler;
+-------------------+
| @@event_scheduler |
+-------------------+
| ON    |
+-------------------+
1 row in set (0.00 sec)

mysql> SHOW VARIABLES LIKE 'event%';
+-----------------+-------+
| Variable_name | Value |
+-----------------+-------+
| event_scheduler | ON |
+-----------------+-------+
1 row in set (0.00 sec)

2、開啟、關閉功能命令:

-- 開啟功能命令:
SET GLOBAL event_scheduler = 1;
SET GLOBAL event_scheduler = ON;
-- 關閉功能命令:
SET GLOBAL event_scheduler = 0;
SET GLOBAL event_scheduler = OFF;

當然,通過命令開啟當數據庫重啟后會自動關閉;

持久化開啟方式:將event_scheduler=1寫到my.cnf配置文件中;如下圖:

常用的事件操作命令:

  • 關閉指定事件: ALTER EVENT 事件名稱 ON COMPLETION PRESERVE DISABLE;
  • 開啟指定事件:ALTER EVENT 事件名稱 ON COMPLETION PRESERVE ENABLE;
  • 查看當前事件:SHOW EVENTS ;

三、事件 - SQL語法創建

下面是EVENT事件創建語句,乍一看挺復雜的,讓我們拆開解讀一下

CREATE EVENT [IFNOT EXISTS] event_name
    ON SCHEDULE schedule(調度時間設置)
    [ON COMPLETION [NOT] PRESERVE]
    [ENABLE | DISABLE | DISABLE ON SLAVE]
    [COMMENT 'comment']
    DO sql_statement;

SQL語法 說明
DEFINER 可選項,給指定用戶使用權限
IF NOT EXISTS 可選項,用于判斷要創建的事件是否存在
EVENT event_name 必選項,指定事件名稱,event_name的最大長度為64個字符,如果為指定event_name,則默認為當前的MySQL用戶名(不區分大小寫)
ON SCHEDULE schedule 必選項,這里的schedule用于定義執行的時間和時間間隔,在下面我們詳細講解
ON COMPLETION [NOT] PRESERVE 可選項,配置事件執行完一次后的處理方式;
當為on completion preserve 的時候,當event到期了,event會被disable,但是該event還是會存在
當為on completion not preserve的時候,當event到期的時候,該event會被自動刪除掉.
ENABLE、DISABLE、DISABLE ON SLAVE 可選項,用于指定事件的一種屬性。
ENABLE表示該事件是開啟的,也就是調度器檢查事件是否必選調用;
DISABLE表示該事件是關閉的,也就是事件的聲明存儲到目錄中,但是調度器不會檢查它是否應該調用;
DISABLE ON SLAVE表示事件在從機中是關閉的。如果不指定這三個選擇中的任意一個,則在一個事件創建之后,它立即變為活動的。
COMMENT ‘comment' 可選項,用于定義事件的注釋
DO event_body 必選項,用于指定事件啟動時所要執行的代碼??梢允侨魏斡行У腟QL語句、存儲過程或者一個計劃執行的事件。如果包含多條語句,可以使用BEGIN…END復合結構

schedule 調度時間配置語法:調度時間配置包括ATEVERY兩種

AT timestamp [+ INTERVAL interval] ...
 | EVERY interval
 [STARTS timestamp [+ INTERVAL interval] ...]
 [ENDS timestamp [+ INTERVAL interval] ...]


-- INTERVAL中包含的時間單位如下:
{YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
 WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
 DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}

1、創建 - 單次定時執行事件

AT TIMESTAMP 時間字符串 [+ INTERVAL INTERVAL]

  AT TIMESTAMP表示該事件只執行一次,TIMESTAMP表示一個具體的時間點,后面可以加上一個時間間隔,表示在這個時間間隔后事件發生。[+ INTERVAL INTERVAL]表示延遲觸發時間;

  需要注意的是,TIMESTAMP和具體字符串連用,如果不是具體字符串(如CURRENT_TIMESTAMP取當前時間等),則不加TIMESTAMP;

示例 1:往demo_1119表中插入一行數據,執行時間:2020-11-20 00:00:00

CREATE EVENT demo_event2 
ON SCHEDULE AT TIMESTAMP '2020-11-20 00:00:00' 
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())

結果查詢:

mysql> select * from demo_1119;
+-----+-----------+---------------------+
| id | name  | createTime   |
+-----+-----------+---------------------+
| 145 | 陳哈哈 | 2020-11-20 00:00:00 |
+-----+-----------+---------------------+
9 rows in set (0.00 sec)

示例 2:往demo_1119表中插入一行數據,執行時間:當前時間往后5個小時;

CREATE EVENT demo_event2 
ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 HOUR
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())

2、創建 - 循環定時執行事件

EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]

EVERY表示循環執行該事件,其中STARTS子句用于指定開始時間;ENDS子句用于指定結束時間。

示例 1:從當前開始,每10秒往demo_1119表中插入一行數據

CREATE EVENT demo_event3 
ON SCHEDULE EVERY 10 SECOND 
ON COMPLETION PRESERVE 
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())
mysql> select * from demo_1119;
+-----+-----------+---------------------+
| id | name  | createTime   |
+-----+-----------+---------------------+
| 145 | 陳哈哈 | 2020-11-19 11:10:39 |
| 146 | 陳哈哈 | 2020-11-19 11:10:49 |
| 147 | 陳哈哈 | 2020-11-20 11:10:59 |
| 148 | 陳哈哈 | 2020-11-20 11:11:09 |
| 149 | 陳哈哈 | 2020-11-20 11:11:19 |
| 150 | 陳哈哈 | 2020-11-20 11:11:29 |
| 151 | 陳哈哈 | 2020-11-20 11:11:39 |
+-----+-----------+---------------------+
9 rows in set (0.00 sec)

示例 2:從2020-11-20 12:00:00開始,每10分鐘往demo_1119表中插入一行數據

CREATE EVENT demo_event4 
ON SCHEDULE EVERY 10 MINUTE STARTS '2020-11-20 12:00:00' 
ON COMPLETION PRESERVE 
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())
mysql> select * from demo_1119;
+-----+-----------+---------------------+
| id | name  | createTime   |
+-----+-----------+---------------------+
| 152 | 陳哈哈 | 2020-11-20 12:00:00 |
| 153 | 陳哈哈 | 2020-11-20 12:10:00 |
| 154 | 陳哈哈 | 2020-11-20 12:20:00 |
| 155 | 陳哈哈 | 2020-11-20 12:30:00 |
| 156 | 陳哈哈 | 2020-11-20 12:40:00 |
+-----+-----------+---------------------+
5 rows in set (0.00 sec)

示例 3:從當前時間一小時后開始,每10分鐘往demo_1119表中插入一行數據;已經測試過可用,我就不再貼冗余查詢的數據咯~

CREATE EVENT demo_event5 
ON SCHEDULE EVERY 10 MINUTE STARTS CURRENT_TIMESTAMP+INTERVAL 1 HOUR 
ON COMPLETION PRESERVE 
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())

示例4:從當前時間一天后開始,每1小時往demo_1119表中插入一行數據,三天后結束

CREATE EVENT demo_event5 
ON SCHEDULE EVERY 1 HOUR 
STARTS CURRENT_TIMESTAMP+INTERVAL 1 DAY 
ENDS CURRENT_TIMESTAMP+INTERVAL 3 DAY 
ON COMPLETION PRESERVE 
DO INSERT INTO `demo_1119` (`id`, `name`, `createTime`) VALUES (null, '陳哈哈', NOW())

示例5:每天零點定時清一下demo_1119表數據

CREATE EVENT demo_event5 
ON SCHEDULE EVERY 1 DAY STARTS '2020-11-20 00:00:00' 
ON COMPLETION PRESERVE 
DO TRUNCATE table `demo_1119`

3、修改事件

修改事件語句跟創建語句如出一轍,語法如下:

ALTER EVENT event_name
    [ONSCHEDULE schedule]
    [old_NAME TO new_NAME]
    [ON COMPLETION [NOT] PRESERVE]
    [COMMENT 'comment']
    [ENABLE | DISABLE]
    [DO sql_statement]

關閉事件任務: ALTER EVENT 事件名稱 ON COMPLETION PRESERVE DISABLE;

開啟事件任務:ALTER EVENT 事件名稱 ON COMPLETION PRESERVE ENABLE;

4、刪除事件

DROP EVENT [IF EXISTS] event_name

四、事件 - 用Navicat創建(推薦)

  很多小伙伴喜歡在命令行敲SQL語句,會有種專業感,但也可能是被領導道德綁架了~~

  就像有些領導們覺得自己員工用Google就很cool😎😎,很帶勁;用百度查 csdn 就很 low。 但作為菜狗的我還是喜歡用我的Navicat小工具和度娘。好了廢話不多說,我們來看看Navicat是如何創建EVENT事件的,GO!

  如下圖,右鍵點擊創建新的事件


  創建事件中的定義一欄是寫執行SQL的,可以包括一條或多條SQL語句、存儲過程等,計劃一欄是定義事件觸發時間的。如下圖,我在執行過程中定義了一條插入語句。


當然也可以同時寫多條SQL,中間帶分號。以BEGIN開頭,END結尾即可。

打開計劃欄,是不是覺得很熟悉!在上個模塊我們都見過。為了使小伙伴們加深印象,我們在回顧一下吧。


參數說明:

AT:表示該事件只執行一次,可以設置一個具體的時間,也可以如圖中CURRENT_TIMESTAMP代表當前時間,后面可以加上一個時間間隔interval,表示在這個時間多久以后后事件發生,表示延遲觸發時間;

  • EVERY:循環執行該事件,其中STARTS子句用于指定開始時間;
  • ENDS子句用于指定結束時間。
  • interval表示從現在開始時間延遲多久以后的一個時間點,其值由一個數值和單位構成。例如,使用“4 WEEK”表示4周后;使用“‘1:10' HOUR_MINUTE”表示1小時10分鐘后。間隔的距離用DATE_ADD()函數來支配。

INTERVAL中包含的時間單位如下:

YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE | WEEK | SECOND |
YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND

好了,讓我們通過一些實例來加深印象: 示例 1:往demo_1119表中插入一行數據,執行時間:2020-11-20 00:00:00

示例

2:往demo_1119表中插入一行數據,執行時間:當前時間往后5個小時;

示例 3:從當前開始,每10秒往demo_1119表中插入一行數據

示例 4:從2020-11-20 12:00:00開始,每10分鐘往demo_1119表中插入一行數據

示例 5:從當前時間一小時后開始,每10分鐘往demo_1119表中插入一行數據;

示例 6:從當前時間一天后開始,每1小時往demo_1119表中插入一行數據,三天后結束

示例 7:每天零點定時清一下demo_1119表數據

到此這篇關于MySQL定時任務(EVENT事件)如何配置詳解的文章就介紹到這了,更多相關MySQL定時任務內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • mysql的計劃任務與事件調度實例分析
  • MySQL計劃任務(事件調度器) Event Scheduler介紹
  • 帶你了解MySQL中的事件調度器EVENT
  • mysql事件之修改事件(ALTER EVENT)、禁用事件(DISABLE)、啟用事件(ENABLE)、事件重命名及數據庫事件遷移操作詳解
  • mysql定時任務(event事件)實現詳解
  • 老生常談mysql event事件調度器(必看篇)
  • MySQL binlog中的事件類型詳解
  • 詳解MySQL用事件調度器Event Scheduler創建定時任務
  • 逐步講解MySQL中定時事件計劃的創建
  • MySQL的事件調度器使用介紹
  • mysql事件的開啟和調用
  • MySQL 使用事件(Events)完成計劃任務

標簽:錦州 荊州 隨州 黑河 吉林 甘南 資陽 滄州

巨人網絡通訊聲明:本文標題《MySQL定時任務(EVENT事件)如何配置詳解》,本文關鍵詞  MySQL,定時,任務,EVENT,事件,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL定時任務(EVENT事件)如何配置詳解》相關的同類信息!
  • 本頁收集關于MySQL定時任務(EVENT事件)如何配置詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 青草青青在线视频观看| 肌肌桶肤肤30分钟大全| 国产综合视频在线观看一区| 我和大佬的三百六十五天| 精品国产污污免费网络入口| 美女黄色片视频| 免费A级毛片在线播放不收费换脸 久久免费观看少妇A级毛片换脸 | 男女互?五十六式图| 男女一边摸一揉很爽下面会变大吗| 寂寞少妇无码A片一区二区免费| 三个女教师被调教成奴| 免费va国产精品小视频| 特a级黄色片| AA级精品无码片国产伦精品| 毒爱韩剧国语版全集免费观看| 娇妻被邻居交换玩弄69XX视频 | 国产99热99| 啊啊啊免费视频| 法国《熟妇的荡欲》| 毛片网站在线播放| Gay男同g片黄网站www| 美女被虐动态图| 黑帮大佬和我的365日第二部| 坐在他嘴上让他添豆豆| 国产精品久久久久久久久久电影网| 女教师2| japanese护士tube在线| 夹看学长的巨大写作业| 办公室做好紧好硬好难受| 美女爱爱网站| 7777av| 右眉尾有痣的女人| 91午夜精品亚洲一区二区三区 | 玖玖玖视频在线观看视频6| vod国产成人精品视频| 美女胸又黄又???| 公交车NP粗暴H强J玩弄| 男生互摸jj| 扒开腿挺进肉嫩小说18禁视频| 神马影院午夜伦| 麻豆蜜桃69无码专区在线|