MySQL从5.1开始支持EVENT功能,类似Oracle和MSSQL的定时任务job功能。有了这个功能之后我们就可以让MySQL自动的执行存储过程来实现数据汇总等功能了,不用像以前哪样手动操作完成了。下面我们来测试下,在MYSQL中如何自动执行指定存储过程,实现相关功能。
一、创建测试表
CREATE TABLE EVENT_table(
id INT auto_increment PRIMARY KEY NOT NULL,
conent VARCHAR(80)
)ENGINE=INNODB DEFAULT CHARSET=utf8;
二、创建调用存储过程
DROP PROCEDURE IF EXISTS pr_event;
CREATE PROCEDURE pr_event(
)
proc_start:BEGIN
INSERT INTO EVENT_table(conent) VALUES ('520');
END proc_start
三、创建事件调用存储过程
创建事件语法:
CREATE EVENT [IF NOT EXISTS] event_name
ON SCHEDULE SCHEDULE
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;
要使定时事件起作用,MySQL的常量GLOBAL event_scheduler必须为on或者是1。
1、查看scheduler的当前状态:
a、SHOW VARIABLES