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; 开启事件

你可能感兴趣的:(MySQL,mysql)