mysql定时任务

今天用到了mysql的定时任务,实现了一个定时更新的功能:

第一步,要创建一个存储过程:
DELIMITER //
CREATE PROCEDURE dr_traffic()  
BEGIN   
INSERT INTO `device_realtime_traffic`(`wifi1_traffic_rx`,`wifi1_traffic_tx`,`wifi2_traffic_rx`,`wifi2_traffic_tx`,`sim1_traffic_rx`,
`sim1_traffic_tx`,`sim2_traffic_rx`,`sim2_traffic_tx`) 
SELECT wifi1_traffic_rx,wifi1_traffic_tx,wifi2_traffic_rx,wifi2_traffic_tx,sim1_traffic_rx,sim1_traffic_tx,sim2_traffic_rx,sim2_traffic_tx
FROM `device_realtime` WHERE dev_mac IN('GD200A159001176','GD200A159001739');
END;

第二步,创建一个事件来调用存储过程:
CREATE event IF NOT EXISTS traffic_event  
ON SCHEDULE EVERY 2 MINUTE  
ON COMPLETION PRESERVE  
DO CALL dr_traffic(); 

每隔2分钟往device_realtime_traffic表中插入2条记录
到这里就可以了,但是之前要注意:
1.查看mysql的事件是否开启:
show variables like '%sche%'
查询出来的结果是:event_scheduler ON,,如果没有开启,请开启定时事件
2.让事件执行/停止:
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、付费专栏及课程。

余额充值