当前位置: 首页 > news >正文

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.

相关文章:

  • kubevirt v1.1.0-alpha.0 offline deploy on kubernetes v1.23.17
  • python多进程multiprocessing
  • nodejs 如何在npm发布自己的包 <记录>
  • JavaScript 期约与异步函数的学习笔记
  • 自定义事件的使用
  • 【FAQ】安防监控系统/视频云存储/监控平台EasyCVR服务器解释器出现变更该如何修改?
  • 代理IP与Socks5代理:跨界电商时代的网络安全与数据引擎
  • 测试与FastAPI应用数据之间的差异
  • Spring Boot虚拟线程与Webflux在JWT验证和MySQL查询上的性能比较
  • arcgis拓扑检查实现多个矢量数据之间消除重叠区域
  • 小程序自定义tabbar
  • Activiti回退与跳转节点
  • python基础语法(四)
  • 什么是HTTP状态码?常见的HTTP状态码有哪些?
  • 下载HTMLTestRunner并修改
  • java.math.BigDecimal常用操作
  • Docker命令
  • ES6-解构赋值
  • python爬虫爬取电影数据并做可视化
  • ip地址怎么改网速快
  • 受贿超8.22亿,新疆维吾尔自治区党委原副书记李鹏新一审被判死缓
  • 新质生产力的宜昌解法:抢滩“高智绿”新赛道,化工产品一克卖数千元
  • 视频·世界读书日|林乾:碎片化阅读或影视综艺≠知识
  • 一季度全国纪检监察机关共处分18.5万人,其中省部级干部14人
  • 《蛮好的人生》上海特色鲜明,聚焦荧屏甚少出现的保险业
  • 深化应用型人才培养,这所高校聘任行业企业专家深度参与专业设置