轉自:http://blog.163.com/xyliufeng2003@126/blog/static/40474592201014113516897/
轉自:http://www.navicat.com.cn/manual/online_manual/cn/navicat/linux_manual/EventsMySQL.html
MySQL 事件计划是在 MySQL 5.1.6 添加。MySQL 事件是按计划运行工作。因此,我们有时称它们为计划事件。当你创建一个事件时,你是创建一个有名的数据库对象,包含在一个或多个规律区间运行一个或多个 SQL 语句,并在特定的日期时间开始及结束。从概念上,这是类似 Windows 任务计划程序的概念。点击 来打开 事件 的对象列表。
定义
定义包括一个有效的 SQL 语句。这可以是一个简单的语句,如 SELECT 或 INSERT,或它可以是一个用 BEGIN 和 END 写的复合语句。复合语句可以包含声明循环和其它控制结构语句。
提示:要自定义编辑器的视图并查看更多 sql 编辑功能,请看编辑器高级功能。
定义者
指定当在事件运行时检查访问权限要使用的用户帐号。默认定义者值是运行 CREATE EVENT 语句的的用户。(这是和 DEFINER = CURRENT_USER 相同。)如果给予一个用户值,它应该是一个 'user_name'@'host_name' 格式的 MySQL 帐号(使用在 GRANT 语句相同的格式)。user_name 及 host_name 值都是必须的。
状态
你可以创建一个事件但可以用 DISABLE 关键字保持不激活。或者,你可以用 ENABLE 来出明确默认状态,这是激活。
ON COMPLETION
正常情况下,一旦事件已过期,它将立即删除。你可以通过指定 ON COMPLETION PRESERVE 来重写此性能。使用 ON COMPLETION NOT PRESERVE 只是使默认非持久性的性能明确。
计划
AT
AT timestamp 用于一次性事件。它指定该事件只运行一次于 timestamp 的日期和时间,它必须同时包含日期和时间,或必须是一个解析为 datetime 值的表达式。使用 +INTERVAL 来创建一个事件,它发生在与当前日期和时间有关的将来某个时候。
EVERY
在定期间隔重复的行动,你可以用一个 EVERY 子句之后是一个 interval。(+INTERVAL 与 EVERY 不能同时使用。)
STARTS
EVERY 子句还可能包含一个非必须的 STARTS 子句。STARTS 之后是一个 timestamp 值表示行动应该何时开始重复,也可以用 +INTERVAL 间隔以指定「由现在开始」的时间量。
例如:EVERY 3 MONTH STARTS CURRENT_TIMESTAMP + 1 WEEK 的意思是「每 3 个月,从现在起一周后开始」。
ENDS
EVERY 子句还可包含一个非必须的 ENDS 子句。ENDS 关键字之后是一个 timestamp 值告诉 MySQL 何时停止重复事件。你也可以用 +INTERVAL 间隔与 ENDS 一起。
例如:EVERY 12 HOUR STARTS CURRENT_TIMESTAMP + INTERVAL 30 MINUTE ENDS CURRENT_TIMESTAMP + INTERVAL 4 WEEK 相当于「每十二个小时,从现在起三十分钟后开始,并于现在起四个星期后结束」。
P.S. | timestamp 必须在未来的 - 你不能安排一个事件发生在过去。 |
interval 区间由两部份组成,数量和时间单位*。 |
-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
SET GLOBAL event_scheduler = 1;
---或我们可以在配置my.ini文件 中加上 event_scheduler = 1
SET GLOBAL event_scheduler = ON;
mysqld ... --event_scheduler=1
SHOW VARIABLES LIKE 'event_scheduler';
SELECT @@event_scheduler;
SHOW PROCESSLIST;
二、创建事件(CREATE EVENT)
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}
USE test; CREATE TABLE aaa (timeline TIMESTAMP); CREATE EVENT e_test_insert ON SCHEDULE EVERY 1 SECOND DO INSERT INTO test.aaa VALUES (CURRENT_TIMESTAMP);
mysql> SELECT * FROM aaa; +---------------------+ | timeline | +---------------------+ | 2007-07-18 20:44:26 | | 2007-07-18 20:44:27 | | 2007-07-18 20:44:28 | +---------------------+
CREATE EVENT e_test ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 DAY DO TRUNCATE TABLE test.aaa;
CREATE EVENT e_test ON SCHEDULE AT TIMESTAMP '2007-07-20 12:00:00' DO TRUNCATE TABLE test.aaa;
CREATE EVENT e_test ON SCHEDULE EVERY 1 DAY DO TRUNCATE TABLE test.aaa;
CREATE EVENT e_test ON SCHEDULE EVERY 1 DAY STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY DO TRUNCATE TABLE test.aaa;
CREATE EVENT e_test ON SCHEDULE EVERY 1 DAY ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAY DO TRUNCATE TABLE test.aaa;
CREATE EVENT e_test ON SCHEDULE EVERY 1 DAY STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTH DO TRUNCATE TABLE test.aaa;
8) 每天定时清空test表(只执行一次,任务完成后就终止该事件):
CREATE EVENT e_test ON SCHEDULE EVERY 1 DAY ON COMPLETION NOT PRESERVE DO TRUNCATE TABLE test.aaa;
[COMMENT ‘comment’]可以给该事件加上注释。
三、修改事件(ALTER EVENT)
ALTER EVENT event_name [ON SCHEDULE schedule] [RENAME TO new_event_name] [ON COMPLETION [NOT] PRESERVE] [COMMENT 'comment'] [ENABLE | DISABLE] [DO sql_statement]
ALTER EVENT e_test DISABLE;
ALTER EVENT e_test ENABLE;
ALTER EVENT e_test ON SCHEDULE EVERY 5 DAY;
四、删除事件(DROP EVENT)
DROP EVENT [IF EXISTS] event_name
DROP EVENT e_test;
DROP EVENT IF EXISTS e_test; 注意:如果你将event执行了Alter event event_name disable.那么当你重新启动mysql服务 器后,该event将被删除(测试版本:5.1.30)
应用案例
- 首先创建存储过程
delimiter // create procedure `Slave_Monitor`() begin SELECT VARIABLE_VALUE INTO @SLAVE_STATUS FROM information_schema.GLOBAL_STATUS WHERE VARIABLE_NAME='SLAVE_RUNNING'; IF ('ON' != @SLAVE_STATUS) THEN SET GLOBAL SQL_SLAVE_SKIP_COUNTER=0; SLAVE START; END IF; end; // delimiter ;
由于存储过程中无法调用类似 SHOW SLAVE STATUS 这样的语句,因此无法得到确切的复制错误信息和错误代码,不能进一步的处理 SLAVE 停止的各种情况。 - 接着,创建任务
CREATE EVENT IF NOT EXISTS `Slave_Monitor` ON SCHEDULE EVERY 5 SECOND ON COMPLETION PRESERVE DO CALL Slave_Monitor();
创建了一个任务,每 5秒钟执行一次,任务结束后依旧保留该任务,而不是删除。当然了,在本例中的任务不会结束,除非将它手动禁止了。 -
如果在运行中想要临时关闭一下某个任务,执行 ALTER EVENT 语句即可:
(root:localhost:)test> alter event `Slave_Monitor` ON COMPLETION PRESERVE DISABLE; (root:localhost:)test> alter event `Slave_Monitor` ON COMPLETION PRESERVE ENABLE;
http://samyu.blog.51cto.com/344284/146011