事件调度器(Event Scheduler)
1. 开启事件调度器
1) SET GLOBAL event_scheduler = 1;
2) 在my.cnf文件中添加event_scheduler = 1
3) SET GLOBAL event_scheduler = ON;
4) 在启动命令加上 --event_scheduler=1
2.关闭事件调度器
1)SET GLOBAL event_scheduler = 0;
2)SET GLOBAL event_scheduler = OFF;
3.查看当前是否已开启事件调度器
1) SHOW VARIALES LIKE 'event_scheduler';
2) SELECT @@event_scheduler;
3) SHOW PROCESSLIST;
事件任务
1.操作事件任务
1) 关闭事件任务:ALTER EVENT eventName ON COMPLETION PRESERVE DISABLE;
2) 开启事件任务:ALTER EVENT eventName ON COMPLETION PRESERVE ENABLE;
3) 查看事件任务:SHOW EVENTS;
2.创建事件
- 语法:
CREATE EVENT [IFNOT EXISTS] event_name
ON SCHEDULE schedule -- 用于定义执行的时间和时间间隔
[ONCOMPLETION [NOT] PRESERVE] -- 设置当前事件是执行一次还是持久执行,默认为一次执行(NOT PRESERVE),PRESERVE的作用是使事件在执行完毕后不会被Drop掉
[ENABLE | DISABLE] -- 设置该事件创建后状态是否开启或关闭,默认为ENABLE
[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}
- 案例:
-- 1.每秒插入一条记录到数据表:
create event e_test_insert
on schedule every 1 second
do insert user values('admin','123');
-- 2.5天后清空test表:
create event e_test
on schedule at current_timestamp+interval 5 day
-- 3.2007年7月20日12点整清空test表:
create event e_test1
on schedule at timestamp '2007-07-20 12:00:00'
do truncate table test
-- 4.每天定时清空test表:
create event test2
on schedule every 1 day
do truncate test
-- 5.5天后开启每天定时清空test表:
create event e_test3
on schedule every 1 day
starts current_timestamp+interval 5 day
do truncate test
-- 6.每天定时清空test表,5天后停止执行:
create event e_test4
on schedule every 1 day
ends current_timestamp+interval 5 day
do truncate test
-- 7.5天后开启每天定时清空test表,一个月后停止
create event e_test5
on schedule every 1 day
starts current_timestamp+interval 5 day
ends current_timestamp+interval 1 month
do truncate test
-- 8.每天定时清空test表(只执行一次,任务完成后就终止该事件)
create event e_test6
on schedule every 1 day
on completion not reserve
do truncate test
3.修改事件
- 语法:
ALTER EVENT event_name
[ONSCHEDULE schedule]
[RENAME TOnew_event_name]
[ON COMPLETION [NOT] PRESERVE]
[COMMENT 'comment']
[ENABLE | DISABLE]
[DO sql_statement]
- 案例
-- 1.临时关闭事件
alter event e_test disable
-- 2.开启事件
alter event e_test enable
-- 3.将每天清空test表改为5天清空一次
alter event e_test
on schedule every 5 day
4.删除事件
- 语法:
DROP EVENT [IF EXISTS] event_name
- 案例:
-- 删除创建的e_test事件
drop event e_test
-- 如果不存在,产生ERROR 1513 (HY000): Unknown event错误
-- 添加if exists
drop event if exists e_test
-- 如果将event执行了Alter event event_name disable.当重新启动mysql服务器后,该event将被删除(测试版本:5.1.30)
计划任务
ONSCHEDULE两种设定计划任务方式:
-- ON SCHEDULE 计划任务,有两种设定计划任务的方式:
1)AT 时间戳,用来完成单次的计划任务
2)EVERY 时间(单位)的数量实践单位[STARTS 时间戳] [ENDS时间戳],用来完成重复的计划任务。
在两种计划任务中,时间戳可以是任意的TIMESTAMP 和DATETIME 数据类型,时间戳需要大于当前时间。
在重复的计划任务中,时间(单位)的数量可以是任意非空(Not Null)的整数式,时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。
提示: 其他的时间单位也是合法的如:QUARTER, WEEK, YEAR_MONTH,DAY_HOUR,DAY_MINUTE,DAY_SECOND,HOUR_MINUTE,HOUR_SECOND,MINUTE_SECOND,不建议使用这些不标准的时间单位。
应用案例
利用 event scheduler 的特性,每秒钟调用一次存储过程,用于判断 SLAVE 是否正常运行,如果发现 SLAVE 关闭了,忽略 0 次错误,然后重新启动 SLAVE。
-- 1)创建存储过程
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;
-- 2)创建定时任务
CREATE EVENT IF NOT EXISTS Slave_Monitor
ON SCHEDULE EVERY 5 SECOND
ON COMPLETION PRESERVE
DO CALL Slave_Monitor();
-- 如果在运行中想要临时关闭一下某个任务,执行 ALTER EVENT 语句即可:
ALTER EVENT Slave_Monitor ON COMPLETION PRESERVE DISABLE; ##关闭事件
ALTER EVENT Slave_Monitor ON COMPLETION PRESERVE ENABLE; ##开启事件