登录  /  注册

mysql定时任务

php中文网
发布: 2016-06-07 15:33:43
原创
1137人浏览过

自 MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。更得 一提的是MySQL的事件调度器可以精确到每秒钟执

      自 MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。更值得 一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务(如:Linux下的CRON或Windows下的任务计划)只能精 确到每分钟执行一次。


1、查看是否开启定时任务:

SHOW VARIABLES LIKE 'event_scheduler';

2、开启定时任务://无需重启

SET GLOBAL event_scheduler = ON;

3、定义定时任务语法:

CREATE EVENT [IF NOT EXISTS] event_name
ON SCHEDULE schedule
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;

-schedule说明:
AT TIMESTAMP [+ INTERVAL INTERVAL]
| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]

INTERVAL:
quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
            WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
            DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}

- on completion preserve 说明:
如在定义event的时候有指定ends,那么是否当到期的时候,
假如使用了on completion preserve,这样这个event还是存在的
但是使用on completion not preserve,这样event就自动删除了


4、实例:

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  


5)每秒插入一条数据

CREATETABLE aaa (timeline TIMESTAMP);
 CREATE EVENT e_test_insert
 ONSCHEDULE EVERY 1 SECOND
 DO INSERT INTO test.aaa VALUES(CURRENT_TIMESTAMP);


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

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


5、查看定时任务:

select * from information_schema.EVENTS;

6、删除定时任务:(最好加上库名)
DROP EVENT IF EXISTS test.aaa_test;  


智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号