本文主要是介绍mysql 大表凌晨定时删除数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
有几张表数据量非常大,一次维护量有点大(一个月有500多万条数据,并且还在往上涨),
于是想了个定时删除数据,每天凌晨执行,这样每天删除数据量就小,
循环删除,每次删除5000条数据,直到当天的数据删除完:
1,做删除过程:
CREATE DEFINER=`root`@`%` PROCEDURE `S_delete_data2`()
BEGIN
#当次删除行数
declare delrows_int int default 0;
#删除月份量
declare Month_int int default -12;
#条件为真循环
loop_label:LOOP
#开启事务(重要!不开的话,100w数据需要论天算)
start transaction;
#测试_删除6个月前的数据
#delete FROM user01 where get_day < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 10000;
#SET delrows_int = delrows_int + ROW_COUNT(); #每删除表记录下删除行数
#select delrows_int;
#删除语句,删除12个月以前的数据,限制每次删除5000条,多张表删除
delete from t_report_167 where SampleTime < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 5000;
SET delrows_int = delrows_int + ROW_COUNT(); #每删除表记录下删除行数
delete from t_report_big_167 where SampleTime < DATE_ADD(CURRENT_DATE,INTERVAL Month_int MONTH) LIMIT 5000;
SET delrows_int = delrows_int + ROW_COUNT(); #每删除表记录下删除行数
IF delrows_int=0 THEN
LEAVE loop_label; #退出循环
END IF;
#测试值显示
#select delrows_int;
IF @@ERROR_COUNT > 0 THEN #判断事务成功与否
ROLLBACK;
ELSE
COMMIT;
END IF;
SET delrows_int =0; #下次改为0
#SELECT SLEEP(3) AS 'Waiting'; #暂停5秒,接收数据库其它操作,防止卡死
END LOOP loop_label;
END
;
2,生成一个定时任务
#创建定时任务(任务名称delete_data)
#创建一个每天定时删除,3点过5分 ,调用过程S_delete_data2()
create event delete_data
ON schedule every 1 day starts DATE_ADD(DATE_ADD(DATE_ADD(CURRENT_DATE(),INTERVAL 1 DAY),INTERVAL 3 HOUR),INTERVAL 5 MINUTE)
do call S_delete_data2();
3,事件调度器必须开启才有效
查看事件调度器是否开启
SHOW VARIABLES LIKE 'event_scheduler';
#开启事件调度器(如果没有开启的话,执行下面)
SET GLOBAL event_scheduler = ON;
4,查看定时任务事件
SELECT event_name,event_definition,interval_value,interval_field,status FROM information_schema.EVENTS;
5,删除定时任务(delete_data是任务名称)
drop event delete_data;
标记下,以后查用
这篇关于mysql 大表凌晨定时删除数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!