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
本文參考:http://www.jz123.cn/text/1134105.html
http://blog.sina.com.cn/s/blog_5ceb51480101ndab.html