[转]MySQL 定时器EVENT学习

 在拓展按月,季,年开展自动调用存储过程 时,为了测试可以把系统改为年的末梢一天,如20十-1二-31 二三:5九:5五;

 

局地例证:

从现在开始每隔九天定时执行
CREATE  EVENT EVENT1

ON SCHEDULE EVERY 9 DAY STARTS NOW()
ON COMPLETION PRESERVE ENABLE
DO
    BEGIN
       CALL TOTAL();
    END




每个月的一号凌晨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



每个季度一号的凌晨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




每年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

创立定时器调用的存款和储蓄进度
DELIMITER $$

MySQL从五.一早先协助event功用,类似oracle的job功效。有了那么些成效之后大家就能够让MySQL自动的施行多少汇总等效果,不用像此前供给操作的接济了。如linux 
crontab功效。

开创测试表
CREATE TABLE t
(
    v VARCHAR(100) NOT NULL
) ENGINE INNODB DEFAULT CHARSET=utf8;

CREATE PROCEDURE e_test()
    BEGIN
        INSERT INTO t VALUES(‘1’);
    END $$
   
DELIMITER ;
要使定时起成效 MySQL的常量GLOBAL event_scheduler必须为on或者是1
— 查看是或不是打开定时器
SHOW VARIABLES LIKE ‘%sche%’; 

正文转自:http://home.searchfull.net:8080/2398965-mysql+定时+event+.html

 

— 关闭事件
ALTER EVENT event_test ON   
COMPLETION PRESERVE DISABLE;

 MySQL的event和Oralce的Job照旧有点不相同的,这一点让作者相比麻烦

以此Oracle的Job就会把月,季,年仓库储存进度执行3次。但MySQL改了系统时间了伊夫nt也从未定时执行。不清楚诸位大虾有未有哪些好办法?能够缓解这几个难题。

— 开启事件
ALTER EVENT event_test ON   
COMPLETION PRESERVE ENABLE;  

DROP PROCEDURE IF EXISTS e_test $$

— 创设事件
–每隔1秒自动调用e_test()存款和储蓄进程
CREATE EVENT IF NOT EXISTS event_test
ON SCHEDULE EVERY 1 SECOND
ON COMPLETION PRESERVE  
DO CALL e_test();

— 开启定时器 0:off 壹:on
SET GLOBAL event_scheduler = 1; 

SELECT * FROM t;

 

相关文章