mysql数据库中定时删除


本文摘自PHP中文网,作者coldplay.xixi,侵删。

mysql数据库中设置定时删除的方法:首先打开mysql文件;然后设置删除三天前的数据,代码为【DELETE FROM table WHERE created_on<DATE_SUB(CURDATE(),INTERVAL 3 DAY)】。

相关免费学习推荐:mysql数据库(视频)

mysql数据库中设置定时删除的方法:

删除三天前的数据的sql

1

DELETE FROM table WHERE created_on < DATE_SUB(CURDATE(),INTERVAL 3 DAY);

  • CURDATE() 返回当前日期

  • CURNOW() 返回当前datetime

  • INTERVAL 是mysql间隔值,用法为INTERVAL expr unit。INTERVAL 3 DAY表示三天的间隔

  • DATE_SUB(start_date,INTERVAL expr unit);

写一个存储过程

存储过程相当于mysql的函数,它是存储在数据库服务器中的一组sql语句,通过调用这个函数的名称来执行这些sql语句命令。

1

2

3

4

5

6

DELIMITER //

create procedure del_data()

BEGIN

DELETE FROM table WHERE created_on < DATE_SUB(CURDATE(),INTERVAL 3 DAY);

END//

DELIMITER ;

  • DELIMITER是分割符的意思,声明存储过程前将"//"声明为分隔符,这样存储过程中的“;”才不会被当作分隔符处理。声明结束后再还原分隔符。

  • 存储过程也可以带参数,存储过程名(参数)

  • 在声明存储过程前要先用use database_name切换到想要应用的数据库,否则存储过程会应用到默认数据库中

查看以及使用存储过程

查看存储过程

1

select * from mysql.proc where db=’数据库名’;

使用存储过程

1

call del_data()

写一个事件

开启事件调度器

1

SET GLOBAL event_scheduler = ON;

创建事件

1

2

3

4

5

create event del_event 

on schedule

EVERY 1 day 

STARTS '2019-3-28 00:00:00' 

do call del_data()

以上就是mysql数据库中定时删除的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

关于mysql 优化 insert 性能 的相关介绍

学习mysql不是内部命令的错误解决方案

mysql慢查询日志的配置以及使用教程详解

mysql中的执行计划explain详解

mysql如何连接数据库

mysql表定义语法详细介绍

mysql修改权限后本地无法登录怎么办

mysql服务器主从数据库同步配置的方法详解

mysql两大存储引擎innodb与myisam的区别

mysql怎么删除某一字段的所有值

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...