今天用到了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;
第二步,创建一个事件来调用存储过程:
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条记录
CREATE event IF NOT EXISTS traffic_event
ON SCHEDULE EVERY 2 MINUTE
ON COMPLETION PRESERVE
DO CALL dr_traffic();
到这里就可以了,但是之前要注意:
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; 开启事件