mysql5.7 定时删除表数据

在 MySQL 5.7 中,你可以使用 Event Scheduler(事件调度器) 来实现这个需求。

以下是完整的步骤和 SQL 代码,分为三个部分:开启调度器创建定时任务验证与维护

🛠️ 第一步:开启事件调度器

默认情况下,MySQL 的事件调度器可能是关闭的。你需要先检查并开启它。

  1. 检查状态:

    sql 复制代码
    SHOW VARIABLES LIKE 'event_scheduler';

    如果 Value 显示为 OFF,请执行下一步。

  2. 开启调度器(临时生效,重启失效):

    sql 复制代码
    SET GLOBAL event_scheduler = ON;

    注意 :如果需要永久生效(重启后依然有效),需要在 MySQL 的配置文件(my.inimy.cnf)的 [mysqld] 部分添加 event_scheduler=ON,然后重启 MySQL 服务。

📝 第二步:创建定时删除任务

我们将创建一个名为 evt_cleanup_invalid_devices 的事件,每分钟执行一次删除操作。

sql 复制代码
DELIMITER $$

CREATE EVENT IF NOT EXISTS evt_cleanup_invalid_devices
ON SCHEDULE EVERY 1 MINUTE
STARTS NOW() -- 立即开始
ON COMPLETION PRESERVE -- 任务持久化,不会因为重启或时间到了就自动删除事件定义
ENABLE
DO
BEGIN
    -- 执行删除操作
    DELETE FROM device WHERE LENGTH(deviceId) != 20;
    
    -- 可选:如果你想记录日志,可以在这里添加插入日志表的语句
    -- INSERT INTO cleanup_log (run_time, rows_affected) VALUES (NOW(), ROW_COUNT());
END$$

DELIMITER ;

代码解释:

  • ON SCHEDULE EVERY 1 MINUTE:设置频率为每分钟一次。
  • STARTS NOW():从当前时间开始执行。
  • ON COMPLETION PRESERVE:这是一个好习惯,表示事件执行后保留定义,否则 MySQL 可能会在特定条件下丢弃事件定义。
  • BEGIN ... END:使用代码块包裹,方便以后扩展(比如添加日志记录)。

🔍 第三步:验证与管理

创建完成后,你可以通过以下方式查看和管理这个定时器:

  1. 查看所有事件:

    sql 复制代码
    SHOW EVENTS;

    查看 Status 是否为 ENABLEDInterval 是否为 1 MINUTE

  2. 查看事件详细信息:

    sql 复制代码
    SELECT * FROM information_schema.EVENTS WHERE EVENT_NAME = 'evt_cleanup_invalid_devices'\G
  3. 手动管理(暂停/恢复/删除):

    • 暂停任务: ALTER EVENT evt_cleanup_invalid_devices DISABLE;
    • 恢复任务: ALTER EVENT evt_cleanup_invalid_devices ENABLE;
    • 删除任务: DROP EVENT IF EXISTS evt_cleanup_invalid_devices;

💡 性能优化建议

如果你的 device 表数据量非常大(例如百万级以上),每分钟全表扫描 LENGTH(deviceId) != 20 可能会比较慢。

为了提升性能,建议给 deviceId 字段加上索引 ,或者利用生成列(Generated Column)来优化查询(但在 MySQL 5.7 中,直接对函数结果建索引有限制,通常建议直接确保 deviceId 字段本身有索引,或者在业务层保证数据质量)。

如果数据量极大,建议使用 LIMIT 分批删除,避免锁表时间过长:

sql 复制代码
-- 高级版:分批删除(避免一次删除太多导致锁表)
DELETE FROM device WHERE LENGTH(deviceId) != 20 LIMIT 1000;

(注:如果数据量特别大,可能需要配合循环逻辑,但在简单的 Event 中,上述单条语句通常足够应对中等规模数据)

相关推荐
云技纵横2 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二2 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
小猿姐2 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
云技纵横3 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神3 天前
三、用户与权限管理
数据库·mysql
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
ApacheSeaTunnel3 天前
实战演示 | 基于 Apache SeaTunnel 与 Apache DolphinScheduler 实现 MySQL 到 Doris 离线定时增量同步
大数据·mysql·开源·doris·数据集成·seatunnel·数据同步
DARLING Zero two♡4 天前
【MySQL数据库】数据类型与表约束
数据库·mysql
活宝小娜4 天前
mysql详细安装教程
数据库·mysql·adb