事件调度器有时也可称为临时触发器(temporal triggers),
因为事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。
在使用这个功能之前必须确保event_scheduler已开启,可执行
开启:
①(开启事件触发器)
1
|
SET GLOBAL event_scheduler = 1 ;
|
或我们可以在配置my.ini文件 中加上 event_scheduler = 1
②或
1
|
SET GLOBAL event_scheduler = ON; |
来开启,也可以直接在启动命令加上“–event_scheduler=1”,例如:
mysqld ... --event_scheduler=1
要查看当前是否已开启事件调度器,可执行如下SQL:
1
2
3
|
SHOW VARIABLES LIKE 'event_scheduler' ;
或 SELECT @ @event_scheduler ;
|
或
拥有 SUPER 权限的账户执行 SHOW PROCESSLIST 就可以看到这个线程了。
在使用事件这个功能,首先要保证你的mysql的版本是5.1以上,然后还要查看你的mysql服务器上的事件是否开启。
如果看到event_scheduler为on
或者PROCESSLIST中显示有event_scheduler的信息说明就已经开启了事件。如果显示为off
或者在PROCESSLIST中查看不到event_scheduler的信息,那么就说明事件没有开启,我们需要开启它。
其他:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
-- 开启事件调度的支持 SET GLOBAL event_scheduler = 1 ;
-- 列出事件 SHOW EVENTS; SHOW CREATE EVENT del_user; -- 查询触发器是否启动。 SHOW VARIABLES LIKE 'event_scheduler' ;
-- 定义存储过程 (修改test表里面的id都为 5 )
DELIMITER //
DROP PROCEDURE IF EXISTS usp_update_test; CREATE PROCEDURE usp_update_test() -- expire_interval: the unit is hour -- delete_per_count: specify the count do every delete operation
BEGIN DECLARE id INT;
SET id= 5 ;
update test set id=id;
END //
DELIMITER ; -- 定义事件 (一分钟执行一次上面的存储过程) DROP EVENT IF EXISTS del_test; CREATE EVENT del_test ON SCHEDULE EVERY 1 MINUTE
DO CALL usp_update_test()
|
本文转自建波李 51CTO博客,原文链接:http://blog.51cto.com/jianboli/1884180,如需转载请自行联系原作者