Chinaunix首页 | 论坛 | 博客
  • 博客访问: 594992
  • 博文数量: 248
  • 博客积分: 52
  • 博客等级: 民兵
  • 技术积分: 1028
  • 用 户 组: 普通用户
  • 注册时间: 2012-12-23 12:05
文章分类

全部博文(248)

文章存档

2016年(7)

2013年(241)

分类: Mysql/postgreSQL

2013-04-08 21:35:59

原文地址:MySQL5.1 event使用方法 作者:alang85

在MySQL5.1中计划调度用创建EVENT在表示。翻译为事物觉得不妥,此事物非Translation。

首先要查看EVENT开关,否则创建的EVENT不会运行。
mysql> select @@event_scheduler;
mysql> show variables like 'event_scheduler';
如果没有开启,开启它。
mysql> set GLOBAL event_scheduler=ON;

mysql> set GLOBAL event_scheduler=1;
--------
创建事物模板

DELIMITER $$

-- SET GLOBAL event_scheduler = ON$$     -- required for event to execute but not create   

CREATE /*[DEFINER = { user | CURRENT_USER }]*/ EVENT `test`.`event_name`

ON SCHEDULE
  /* uncomment the example below you want to use */

 -- scheduleexample 1: run once

    --  AT 'YYYY-MM-DD HH:MM.SS'/CURRENT_TIMESTAMP { + INTERVAL 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...] }

 -- scheduleexample 2: run at intervals forever after creation

    -- EVERY 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...]

 -- scheduleexample 3: specified start time, end time and interval for execution
    /*EVERY 1  [HOUR|MONTH|WEEK|DAY|MINUTE|...]

    STARTS CURRENT_TIMESTAMP/'YYYY-MM-DD HH:MM.SS' { + INTERVAL 1[HOUR|MONTH|WEEK|DAY|MINUTE|...] }

    ENDS CURRENT_TIMESTAMP/'YYYY-MM-DD HH:MM.SS' { + INTERVAL 1 [HOUR|MONTH|WEEK|DAY|MINUTE|...] } */

/*[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']*/

DO
 BEGIN
     (sql_statements)
 END$$

DELIMITER ;

例如创建一个EVENT,每5分钟执行,如下:

DELIMITER $$

CREATE  EVENT `event_sync` ON SCHEDULE EVERY 5 MINUTE
ON COMPLETION PRESERVE ENABLE
DO
BEGIN
CALL pro_sync();  //调用存储过程时,如果此存储过程没有实参为NULL,必须加上()否则,事物不执行。
END$$

DELIMITER ;

阅读(1004) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~