首页 / MYSQL / MySQL事件调度器_MySQL
MySQL事件调度器_MySQL
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL事件调度器_MySQL,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2848字,纯文字阅读大概需要5分钟。
内容图文
![MySQL事件调度器_MySQL](/upload/InfoBanner/zyjiaocheng/577/2aae1bf06e1147dc8888c0e34e932b57.jpg)
MySQL 5.1 中新增了事件调度器这一个功能。可以实现类似于SQL Server的Job功能。
1.语法:
CREATE EVENT [IF NOT EXISTS] event_nameON SCHEDULE schedule [ON COMPLETION [NOT] PRESERVE][ENABLE | DISABLE][COMMENT 'comment']DO sql_statement;View Code
其中schedule的语句可以表示为:
AT TIMESTAMP [+ INTERVAL]| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]View Code
interval的单位可以有如下几种:
YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE | DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECONDView Code
2.开启、关闭事件调度器:
在使用这个功能之前必须确保event_scheduler已开启.
/*开启*/SET GLOBAL event_scheduler = 1;-- 或SET GLOBAL event_scheduler = ON;/*关闭*/SET GLOBAL event_scheduler = 0;-- 或SET GLOBAL event_scheduler = OFF;View Code
3.示例:
创建测试数据库:
CREATE TABLE tst_event (createtime DATETIME);View Code
创建测试用存储过程:
/*创建测试用存储过程*/CREATE PROCEDURE msp_TestEvent()BEGIN INSERT INTO tst_event VALUES (CURRENT_TIMESTAMP);ENDView Code
创建事件调度器:
CREATE EVENT IF NOT EXISTS me_TestEvent ON SCHEDULE EVERY 10 SECOND STARTS '2014-02-28 16:45:00' ENDS DATE_ADD('2014-02-28 16:46:00',INTERVAL 1 SECOND) DO CALL msp_TestEvent();View Code
修改事件调度器:
/*修改EVENT*/ ALTER EVENT me_TestEvent ON SCHEDULE EVERY 10 SECOND STARTS '2014-02-27 16:45:00' ENDS DATE_ADD('2014-02-27 16:46:00',INTERVAL 1 SECOND) DO INSERT INTO tst_event VALUES (CURRENT_TIMESTAMP);View Code
查看事件调度器:
/*查看EVENT*/ show events;-- 或select * from information_schema.eventsView Code
4.不同时间间隔的调度:
一天后执行调度器:
/*一天后执行调度器T*/ CREATE EVENT e_TestEventON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 1 DAYDO CALL msp_TestEvent();View Code
2014-02-28日执行调度器:
/*2014-02-28日执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE AT TIMESTAMP '2014-02-28 00:00:00'DO CALL msp_TestEvent();View Code
每天执行调度器:
/*每天执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYDO CALL msp_TestEvent();View Code
一天后每天执行调度器:
/*一天后每天执行调度器*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 2 DAYDO CALL msp_TestEvent();View Code
每天执行调度器,10天后停止:
/*每天执行调度器,10天后停止*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 DAYDO CALL msp_TestEvent();View Code
一天后开始,每天执行调度器,10天后停止:
/*一天后开始,每天执行调度器,10天后停止*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYSTARTS CURRENT_TIMESTAMP + INTERVAL 1 DAYENDS CURRENT_TIMESTAMP + INTERVAL 10 MONTHDO CALL msp_TestEvent();View Code
每天执行调度器,只执行一次:
/*每天执行调度器,只执行一次*/ CREATE EVENT e_TestEventON SCHEDULE EVERY 1 DAYON COMPLETION NOT PRESERVEDO CALL msp_TestEvent();View Code
5.删除调度器:
DROP EVENT [IF EXISTS] event_nameView CodebitsCN.com
内容总结
以上是互联网集市为您收集整理的MySQL事件调度器_MySQL全部内容,希望文章能够帮你解决MySQL事件调度器_MySQL所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。