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;

标记下,以后查用

相关推荐

  1. mysql 凌晨定时删除数据

    2024-04-13 15:54:03       32 阅读
  2. mysql 删除分区数据

    2024-04-13 15:54:03       49 阅读
  3. mysql 存储过程 每天凌晨 定时执行任务(存储过程)

    2024-04-13 15:54:03       39 阅读
  4. Mysql数据删除

    2024-04-13 15:54:03       52 阅读
  5. 安全快速地删除 MySQL 数据并释放空间

    2024-04-13 15:54:03       58 阅读
  6. MySQL数据库基础知识之添加修改删除记录

    2024-04-13 15:54:03       41 阅读
  7. mysql定时任务事件清理单数据

    2024-04-13 15:54:03       25 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-13 15:54:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-13 15:54:03       101 阅读
  3. 在Django里面运行非项目文件

    2024-04-13 15:54:03       82 阅读
  4. Python语言-面向对象

    2024-04-13 15:54:03       91 阅读

热门阅读

  1. 【J1】【map】考试

    2024-04-13 15:54:03       27 阅读
  2. linux下根据进程pid获取对应的window id的方法

    2024-04-13 15:54:03       33 阅读
  3. 【leetcode面试经典150题】44. 两数之和(C++)

    2024-04-13 15:54:03       34 阅读
  4. P8715 [蓝桥杯 2020 省 AB2] 子串分值 (双边检测)

    2024-04-13 15:54:03       30 阅读
  5. 2025秋招复习计划

    2024-04-13 15:54:03       38 阅读
  6. 我可以信任XEX吗?

    2024-04-13 15:54:03       33 阅读
  7. 实战自动化修改主机名

    2024-04-13 15:54:03       34 阅读
  8. 以太坊源码阅读01

    2024-04-13 15:54:03       29 阅读
  9. 有哪些更复杂的并发编程概念可以进一步学习?

    2024-04-13 15:54:03       43 阅读
  10. 数据结构----堆 和 堆排序 代码

    2024-04-13 15:54:03       38 阅读