MYSQL-定时任务(event)

作者:谢高升 发布:2017-10-13 浏览:2051次

之前删除数据或者是更改数据都是在服务器上写个脚本跑定时任务,crontab写了很多任务;

mysql 5.1之后支持事件之后可以很方便的去执行了;

例如我要每天晚上23点去清空clients表;


查看mysql是否开启事件;

show variables like 'event_scheduler' ;

开启
set global event_scheduler =1;

创建事件

#更改一下; 为$$ 在cmd命令行之行
DELIMITER $$
CREATE  EVENT `clients`
ON SCHEDULE EVERY 1 DAY STARTS '2017-10-13 23:00:00' 
DO BEGIN
   #干你想干的事情 insert delete update都可以
  truncate table clients;
END $$
DELIMITER ;

# 每天执行就是1 day  每周 1 week  每小时 1 HOUR  1 MINUTE

查看事件

show events;

image.png


如果是要设置几天后执行又不想去计算时间 例如5天后开始执行

DELIMITER $$
CREATE  EVENT `clients`
ON SCHEDULE EVERY 1 DAY CURRENT_TIMESTAMP+ INTERVAL 5 DAY 
DO BEGIN
   #干你想干的事情 insert delete update都可以
  truncate table clients;
END $$
DELIMITER ;


如果 是5天后停止 加ends

DELIMITER $$
CREATE  EVENT `clients`
ON SCHEDULE EVERY 1 DAY ENDS ENDSCURRENT_TIMESTAMP+ INTERVAL 5 DAY 
DO BEGIN
   #干你想干的事情 insert delete update都可以
  truncate table clients;
END $$
DELIMITER ;