`
hzl7652
  • 浏览: 117939 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

MySQL 定时器EVENT学习

阅读更多

MySQL 定时器EVENT学习

MySQL从5.1开始支持event功能,类似oracle的job功能。有了这个功能之后我们就可以让MySQL自动的执行数据汇总等功能,不用像以前需要操作的支持了。如linux  crontab功能

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

 

创建定时器 调用的存储过程
DELIMITER $$

DROP PROCEDURE IF EXISTS e_test $$

CREATE PROCEDURE e_test()
    BEGIN
        INSERT INTO t VALUES('1');
    END $$
   
DELIMITER ;
要使定时起作用
MySQL的常量GLOBAL event_scheduler必须为on或者是1
-- 查看是否开启定时器
SHOW VARIABLES LIKE '%sche%'; 

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

-- 创建事件
--每隔一秒自动调用e_test()存储过程
CREATE EVENT IF NOT EXISTS event_test
ON SCHEDULE EVERY 1 SECOND
ON COMPLETION PRESERVE  
DO CALL e_test();

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

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

SELECT * FROM t;

 

一些例子:


 
从现在开始每隔九天定时执行
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
	

 MySQL的event和Oralce的Job还是有点不同的,这点让笔者比较困扰

 在进行按月,季,年进行自动调用存储过程 时,为了测试可以 把系统改为年的最后一天,如2010-12-31 23:59:55;

这个Oracle的Job就会把月,季,年存储过程执行一遍。但MySQL改了系统时间了Event也没有定时执行。不知道各位大虾有没有什么好办法?可以解决这个问题。

 

5
1
分享到:
评论
4 楼 hzl7652 2012-09-05  
zhuyuangping 写道
hzl7652 写道
zhuyuangping 写道
其实Mysql记录的是启动时间和时间间隔,通过系统时间,三个数值来计算下一个休眠时间,所以在休眠期间内改变系统时间,对休眠时间是无效的。关于Mysq 事件EVENTl那点事。http://zhuyuangping.iteye.com/admin/blogs/1669577


那你们如何测试触发时间的?比如每年执行一次,每月执行一次那种功能

可以试试启动时间推后,因为它是根据启动时间和时间间隔去计算休眠时间的。但是,只能测试一次,因为只要它执行完任务,就会再次计算休眠时间



可以试试启动时间推后? 如何推后
3 楼 zhuyuangping 2012-09-03  
hzl7652 写道
zhuyuangping 写道
其实Mysql记录的是启动时间和时间间隔,通过系统时间,三个数值来计算下一个休眠时间,所以在休眠期间内改变系统时间,对休眠时间是无效的。关于Mysq 事件EVENTl那点事。http://zhuyuangping.iteye.com/admin/blogs/1669577


那你们如何测试触发时间的?比如每年执行一次,每月执行一次那种功能

可以试试启动时间推后,因为它是根据启动时间和时间间隔去计算休眠时间的。但是,只能测试一次,因为只要它执行完任务,就会再次计算休眠时间
2 楼 hzl7652 2012-09-03  
zhuyuangping 写道
其实Mysql记录的是启动时间和时间间隔,通过系统时间,三个数值来计算下一个休眠时间,所以在休眠期间内改变系统时间,对休眠时间是无效的。关于Mysq 事件EVENTl那点事。http://zhuyuangping.iteye.com/admin/blogs/1669577


那你们如何测试触发时间的?比如每年执行一次,每月执行一次那种功能
1 楼 zhuyuangping 2012-09-01  
其实Mysql记录的是启动时间和时间间隔,通过系统时间,三个数值来计算下一个休眠时间,所以在休眠期间内改变系统时间,对休眠时间是无效的。关于Mysq 事件EVENTl那点事。http://zhuyuangping.iteye.com/admin/blogs/1669577

相关推荐

Global site tag (gtag.js) - Google Analytics