MySQL定时事件

自 MySQL5.1.6起,增长了一个很是有特点的功能–事件调度器(Event Scheduler),能够用作定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操做系统的计划任务来执行的工做。更值得 一提的是MySQL的事件调度器能够精确到每秒钟执行一个任务,而操做系统的计划任务(如:Linux下的CRON或Windows下的任务计划)只能精 确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就很是适合。
  事件调度器有时也可称为临时触发器(temporal triggers),由于事件调度器是基于特定时间周期触发来执行某些任务,而触发器(Triggers)是基于某个表所产生的事件触发的,区别也就在这里。mysql

开启事件
  在使用这个功能以前必须确保event_scheduler已开启,可执行sql

SET GLOBAL event_scheduler = 1;

   ---或咱们能够在配置my.cnf文件 中加上 event_scheduler = 1
  或
spa

SET GLOBAL event_scheduler = ON;

  来开启,也能够直接在启动命令加上“--event_scheduler=1”,例如:
  mysqld ... --event_scheduler=1
  要查看当前是否已开启事件调度器,可执行以下SQL:
操作系统

SHOW VARIABLES LIKE 'event_scheduler';

  或
code

SELECT @@event_scheduler;

  或  orm

SHOW PROCESSLIST;

建立事件事件

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}

其中,
event_name:定时器名,最大长度64个字符,若未指定,则默认为当前的MySQL用户名(不区分大小写);it

schedule:限定执行时间;event

ON COMPLETION [NOT] PRESERVE:表示是否须要循环复用这个Event;class

sql_statement:要执行的SQL语句(也能够使用存储过程代替传统的SQL语句);

comment:对该时间调度器的一个注释,最大长度64个字符;

关闭事件

ALTER EVENT event_name ON
COMPLETION PRESERVE DISABLE;

开启事件

ALTER EVENT event_name ON
COMPLETION PRESERVE ENABLE;

删除事件

DROP EVENT [IF EXISTS] event_name

范例

天天凌晨1点开始执行数据更新:

CREATE EVENT [IF NOT EXISTS] E_testEvent_1 
	ON SCHEDULE EVERY 1 DAY STARTS DATE_ADD(DATE_ADD(CURDATE(), INTERVAL 1 DAY), INTERVAL 1 HOUR) 
	ON COMPLETION PRESERVE ENABLE 
	DO
		UPDATE _T_test SET col= 2 where ValidityDate < now();

每个月第一天凌晨1点开始执行数据更新(使用存储过程):

CREATE EVENT E_testEvent_2 
ON SCHEDULE EVERY 1 MONTH STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY), INTERVAL 1 MONTH),INTERVAL 1 HOUR)
ON COMPLETION PRESERVE ENABLE
DO
BEGIN
CALL P_testProcedureName();
END

每季度第一天凌晨1点开始执行数据更新:

CREATE EVENT E_testEvent_3  
ON SCHEDULE EVERY 1 QUARTER STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR)
ON COMPLETION PRESERVE ENABLE
DO
UPDATE _T_test SET col= 2 where ValidityDate < now();

2007年7月20日12点整清空test表

CREATE EVENT e_test
 ONSCHEDULE AT TIMESTAMP '2007-07-20 12:00:00'
 DO TRUNCATETABLE test.aaa;
相关文章
相关标签/搜索