MySql事件计划任务

DROP EVENT IF EXISTS eve1;

DELIMITER $$

CREATE EVENT eve1 ON SCHEDULE EVERY 1 SECOND STARTS NOW() ENDS NOW()+1
ON COMPLETION PRESERVE
DISABLE
DO
BEGIN
UPDATE testtable1 SET age = age+1 WHERE id = 1;
END$$

DELIMITER ;

SELECT * FROM testtable1;
SELECT NOW();



/*
标准创建语句EventsEvents

CREATE EVENT 事件任务名称 ON SCHEDULE AT 时戳/EVERY 任意非空的整数 时间单位 [STARTS 时戳] [ENDS时戳]
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT '时间任务注释']
DO
BEGIN
要执行的sql语句
END

ON SCHEDULE有两种设定计划任务的方式:
AT 时戳:单次的计划任务
EVERY 任意非空的整数 时间单位 [STARTS 时戳] [ENDS时戳]:重复的计划任务

设置了[STARTS 时戳] [ENDS时戳]表示只在该时间段内重复计划任务
时戳可以是任意的TIMESTAMP 和DATETIME 数据类型。
要求提供的是将来的时间(大于CURRENT_TIMESTAMP),而且小于Unix时间的最后时间(等于或小于'2037-12-31 23:59:59')。
时间单位是关键词:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。
提示: 其他的时间单位也是合法的如:QUARTER, WEEK, YEAR_MONTH,DAY_HOUR, DAY_MINUTE, DAY_SECOND, HOUR_MINUTE,HOUR_SECOND, MINUTE_SECOND,但他们是非标准不实用也不需要的。


[ON COMPLETION [NOT] PRESERVE]:
不写默认是 ON COMPLETION NOT PRESERVE,表示当这个事件不会再发生的时候,即当单次计划任务执行完毕后或当重复性的计划任务执行到了ENDS阶段,该事件任务即被drop掉。
ON COMPLETION PRESERVE 当事件任务结束后不被drop掉
提示: 基本不需要试用这个语句。


[ENABLE | DISABLE]
不写默认是ENABLE
设定事件的状态,如果是Enable 的话,那么系统就会启动这个事件,DISABLE则不启动
可以用修改命令开启或关闭事件,修改事件任务只要把关键字CREATE换成ALTER即可。
*/

转载于:https://www.cnblogs.com/dreamhome/archive/2012/10/25/2739037.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值