mysql如何定时执行

5.1版本以后,MYSQL支持定时执行(event)的功能,就跟linux的crontab差不多。

先查看一下你的MSYQL版本,查询版本信息的SQL语句:

select VERSION()

 确定版本支持之后,再查看一下event是否开启:

show variables like '%sche%'; 

 如果未开启,那如何开启呢?

show VARIABLES LIKE '%sche%';
set global event_scheduler =1;
show VARIABLES LIKE '%sche%';

 一般定时执行有2种:

1、从具体一个时间点开始,每隔一段时间执行一次;

从现在开始,每30秒执行一次

create event if not exists e_test
on schedule every 30 second starts now()
on completion preserve
do
INSERT into sdb_yoyi (yoyiscid,orderid) VALUES(2,3)

 2、从具体一个时间点开始,在当日的某个时间点进行执行;

每个月的一号凌晨1点执行

create event if not exists e_test2
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
do
INSERT into sdb_yoyi (yoyiscid,orderid) VALUES(2,3)
 

也可以对事件任务进行关闭:

alter event e_test ON    
COMPLETION PRESERVE DISABLE; 

 对已经关闭的事件任务进行开启:

alter event e_test ON    
COMPLETION PRESERVE ENABLE;
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值