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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql 手动执行event_MYSQL 定时自动执行EVENT

發布時間:2025/3/15 数据库 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql 手动执行event_MYSQL 定时自动执行EVENT 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MySQL從5.1開始支持EVENT功能,類似Oracle和MSSQL的定時任務job功能。有了這個功能之后我們就可以讓MySQL自動的執行存儲過程來實現數據匯總等功能了,不用像以前哪樣手動操作完成了。下面我們來測試下,在MYSQL中如何自動執行指定存儲過程,實現相關功能。

一、創建測試表

CREATE TABLE EVENT_table(

id INT auto_increment PRIMARY KEY NOT NULL,

conent VARCHAR(80)

)ENGINE=INNODB DEFAULT CHARSET=utf8;

二、創建調用存儲過程

DROP PROCEDURE IF EXISTS pr_event;

CREATE PROCEDURE pr_event(

)

proc_start:BEGIN

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

END proc_start

三、創建事件調用存儲過程

創建事件語法:

CREATE EVENT [IF NOT EXISTS] event_name

ON SCHEDULE SCHEDULE

[ON COMPLETION [NOT] PRESERVE]

[ENABLE | DISABLE]

[COMMENT 'comment']

DO sql_statement;

要使定時事件起作用,MySQL的常量GLOBAL event_scheduler必須為on或者是1。

1、查看scheduler的當前狀態:

a、SHOW VARIABLES LIKE 'event_scheduler';

b、SELECT @@event_scheduler;

2、修改scheduler狀態為打開(0:off??,??1:on):

SHOW VARIABLES LIKE 'event_scheduler';-- 查看是否開啟定時器(OFF:關閉,ON:開啟)

打開定時器(四種方式):

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、創建事件,設置每10分鐘執行一次(調用pr_event存儲過程)。

CREATE EVENT IF NOT EXISTS ent_test

ON SCHEDULE EVERY 10 MINUTE

-- ON COMPLETION PRESERVE??????-- 當EVENT到期時,EVENT會被disable,但是該EVENT還是會存在

-- ON COMPLETION NOT PRESERVE??-- 當EVENT到期時,該EVENT會被自動刪掉,該項為默認值

DO CALL pr_event(); -- pr_event()為需要定時處理的存儲過程,這里也可以改成相關SQL可執行語句

4、開啟事件ALTER EVENT ent_test ENABLE;

5、臨時關閉事件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、查看指定事件的詳細信息

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

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

9、查看事件的創建SQL語句

SHOW CREATE EVENT ent_test;

四、一些典型應用示例:

1、從現在開始每隔九天定時執行

CREATE EVENT EVENT1

ON SCHEDULE EVERY 9 DAY STARTS NOW()

ON COMPLETION PRESERVE ENABLE

DO

BEGIN

CALL TOTAL();

END

2、每個月的一號凌晨1 點執行

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、每個季度一號的凌晨2點執行

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號凌晨四點執行

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還是有點不同的,這點讓筆者比較困擾

5、在進行按月,季,年進行自動調用存儲過程時,為了測試可以把系統改為年的最后一天,如2010-12-31 23:59:55;

這個Oracle的Job就會把月,季,年存儲過程執行一遍。但MySQL改了系統時間了Event也沒有定時執行。不知道各位大蝦有沒有什么好辦法?可以解決這個問題。

五、查看事件運行基本信息

SELECT * FROM information_schema.events ORDER BY last_executed DESC

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

SHOW EVENTS

http://blog.sina.com.cn/s/blog_5ceb51480101ndab.html

總結

以上是生活随笔為你收集整理的mysql 手动执行event_MYSQL 定时自动执行EVENT的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。