MySQL定时删除XX天数据

写在前面

定时删除数据方式有多种方法,在实际工作中很多人可能会通过编码实现,也有人可能会通过脚本定时执行SQL进行定时删除对应数据。

今天使用MySQL自带的删除策略。

MYSQL删除策略

从MySQL5.1.6起,增加了一个非常有特色的功能–事件调度器(Event Scheduler),可以用做定时执行某些特定任务(例如:删除记录、对数据进行汇总等等),来取代原先只能由操作系统的计划任务来执行的工作。

更值得一提的是MySQL的事件调度器可以精确到每秒钟执行一个任务,而操作系统的计划任务只能精确到每分钟执行一次。对于一些对数据实时性要求比较高的应用(例如:股票、赔率、比分等)就非常适合。

如何使用

1、开启事件调度器,确认是否开启

SHOW VARIABLES LIKE 'event_scheduler';

如果看到的结果是 OFF

则代表没有开启事件调度器,需要执行下面的命令进行开启。

-- 开启命令
SET GLOBAL event_scheduler = ON;

2.创建事件 例如定时删除三个月前的数据

create event delete_old_data
on schedule every 1 day starts '2023-01-1 23:35:00'
do delete from tb_processinfo
where Datatime < DATE_SUB(NOW(),INTERVAL 3 MONTH)

就这样使用MySQL定时删除任务就做好了。

为了查看对应事件执行情况以及手动开启、关闭、删除事件还得需要了解一下几个命令。

-- 查看事件
show events;

-- 关闭事件
alter event event_name disable

-- 开启事件
alter event event_name enable;

-- 删除事件
drop event if exists event_name;

小结

通过使用MySQL的事件调度器,我们可以方便地创建定时任务来定期清理数据库中的过期数据。本文介绍了如何创建定时任务以及如何删除3个月前的数据作为示例。

请根据实际需求进行相应的调整和扩展。定时任务是数据库管理的重要组成部分,合理使用定时任务可以有效提高数据库性能和管理效率。

tips:为了保证数据的安全性,请在操作前进行备份,并谨慎执行删除操作。


The end.

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值