mysql数据库中定时删除

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

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

MysqL数据库中设置定时删除方法

删除三天前的数据的sql

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语句命令。

DELIMITER // 
create procedure del_data()
BEGIN
DELETE FROM table WHERE created_on < DATE_SUB(CURDATE(),INTERVAL 3 DAY);
END//
DELIMITER ;
  • DELIMITER是分割符的意思,声明存储过程前将//声明为分隔符,这样存储过程中的“;”才不会被当作分隔符处理。声明结束后再还原分隔符。

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

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

查看以及使用存储过程

查看存储过程

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

使用存储过程

call del_data()

一个事件

开启事件调度器

SET GLOBAL event_scheduler = ON;

创建事件

create event del_event  
on schedule 
EVERY 1 day  
STARTS '2019-3-28 00:00:00'  
do call del_data()

相关文章

目录MySQL卸载环境查看是否已安装MySQL卸载mysql服务查看是否...
目录数据类型数据类型分类数值类型以TINYINT认识整型族有符号...
目录表的约束空属性非空约束(NOT NULL Constraint)默认值定...
目录函数时间日期函数:字符串函数数学函数其他函数 函数 时间...
目录使用C语言连接库的安装C APImysql_initmysql_real_conne...
目录用户用户管理查询所有用户查看当前用户查看当前连接数创...