日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

MYSQL 定时自动执行任务

發(fā)布時(shí)間:2023/12/10 数据库 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MYSQL 定时自动执行任务 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.



MYSQL5.1開(kāi)始支持EVENT功能,類似Oracle和MSSQL的定時(shí)任務(wù)job功能。有了這個(gè)功能之后我們就可以讓MySQL自動(dòng)的執(zhí)行存儲(chǔ)過(guò)程來(lái)實(shí)現(xiàn)數(shù)據(jù)匯總等功能了,不用像以前哪樣手動(dòng)操作完成了。下面我們來(lái)測(cè)試下,在MYSQL中如何自動(dòng)執(zhí)行指定存儲(chǔ)過(guò)程,實(shí)現(xiàn)相關(guān)功能。

一、創(chuàng)建測(cè)試表
CREATE TABLE EVENT_table(
id INT auto_increment PRIMARY KEY NOT NULL,
conent VARCHAR(80)
)ENGINE=INNODB DEFAULT CHARSET=utf8;

?

二、創(chuàng)建調(diào)用存儲(chǔ)過(guò)程
DROP PROCEDURE IF EXISTS pr_event;
CREATE PROCEDURE pr_event(
)
proc_start:BEGIN

INSERT INTO??EVENT_table(conent) VALUES ('520');

END proc_start

?

三、創(chuàng)建事件調(diào)用存儲(chǔ)過(guò)程

創(chuàng)建事件語(yǔ)法:

CREATE EVENT [IF NOT EXISTS] event_name
ON SCHEDULE SCHEDULE
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;
要使定時(shí)事件起作用,MySQL的常量GLOBAL event_scheduler必須為on或者是1。
1、查看scheduler的當(dāng)前狀態(tài):
a、SHOW VARIABLES LIKE 'event_scheduler';
b、SELECT @@event_scheduler;

2、修改scheduler狀態(tài)為打開(kāi)(0:off??,??1:on):
SHOW VARIABLES LIKE 'event_scheduler';-- 查看是否開(kāi)啟定時(shí)器(OFF:關(guān)閉,ON:開(kāi)啟)

打開(kāi)定時(shí)器(四種方式):

a、SET GLOBAL event_scheduler=ON;
b、SET @@global.EVENT_scheduler=ON;
c、SET GLOBAL event_scheduler=1;
d、SET @@global.event_scheduler=1;

3、創(chuàng)建事件,設(shè)置每10分鐘執(zhí)行一次(調(diào)用pr_event存儲(chǔ)過(guò)程)。
CREATE EVENT IF NOT EXISTS ent_test
ON SCHEDULE EVERY 10 MINUTE
-- ON COMPLETION PRESERVE??????-- 當(dāng)EVENT到期時(shí),EVENT會(huì)被disable,但是該EVENT還是會(huì)存在
-- ON COMPLETION NOT PRESERVE??-- 當(dāng)EVENT到期時(shí),該EVENT會(huì)被自動(dòng)刪掉,該項(xiàng)為默認(rèn)值
DO CALL pr_event(); -- pr_event()為需要定時(shí)處理的存儲(chǔ)過(guò)程,這里也可以改成相關(guān)SQL可執(zhí)行語(yǔ)句

4、開(kāi)啟事件
ALTER EVENT ent_test ENABLE;

5、臨時(shí)關(guān)閉事件
ALTER EVENT ent_test DISABLE;

6、重命名事件并加上備注
ALTER EVENT test.ent_test RENAME TO ent_test_new COMMENT '重命名事件ent_test';

7、刪除事件

DROP EVENT IF EXISTS ent_test;

8、查看指定事件的詳細(xì)信息

SELECT * FROM information_schema.EVENTS WHERE event_name='ent_test';

SELECT * FROM information_schema.EVENTS WHERE event_name LIKE CONCAT('%','ent_test','%');

9、查看事件的創(chuàng)建SQL語(yǔ)句

SHOW CREATE EVENT ent_test;


四、一些典型應(yīng)用示例:

1、從現(xiàn)在開(kāi)始每隔九天定時(shí)執(zhí)行

  CREATE EVENT EVENT1

  ON SCHEDULE EVERY 9 DAY STARTS NOW()

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL TOTAL();

  END

2、每個(gè)月的一號(hào)凌晨1 點(diǎn)執(zhí)行

  CREATE EVENT EVENT2

  ON SCHEDULE EVERY 1 MONTH STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL STAT();

  END

3、每個(gè)季度一號(hào)的凌晨2點(diǎn)執(zhí)行

  CREATE EVENT TOTAL_SEASON_EVENT

  ON SCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL SEASON_STAT();

  END

4、每年1月1號(hào)凌晨四點(diǎn)執(zhí)行

  CREATE EVENT TOTAL_YEAR_EVENT

  ON SCHEDULE EVERY 1 YEAR STARTS DATE_ADD(DATE(CONCAT(YEAR(CURDATE()) + 1,'-',1,'-',1)),INTERVAL 4 HOUR)

  ON COMPLETION PRESERVE ENABLE

  DO

  BEGIN

  CALL YEAR_STAT();

  END

  MySQL的event和Oralce的Job還是有點(diǎn)不同的,這點(diǎn)讓筆者比較困擾

5、在進(jìn)行按月,季,年進(jìn)行自動(dòng)調(diào)用存儲(chǔ)過(guò)程時(shí),為了測(cè)試可以把系統(tǒng)改為年的最后一天,如2010-12-31 23:59:55;

  這個(gè)Oracle的Job就會(huì)把月,季,年存儲(chǔ)過(guò)程執(zhí)行一遍。但MySQL改了系統(tǒng)時(shí)間了Event也沒(méi)有定時(shí)執(zhí)行。不知道各位大蝦有沒(méi)有什么好辦法?可以解決這個(gè)問(wèn)題。

?

?五、查看事件運(yùn)行基本信息

SELECT * FROM information_schema.events ORDER BY last_executed DESC

SELECT?*?FROM?mysql.event ORDER?BY?last_executed?DESC

SHOW EVENTS


創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的MYSQL 定时自动执行任务的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。