mysql定时删除数据

删除三天前的数据的sql

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

CURDATE() 返回当前日期mysql

CURNOW() 返回当前datetimesql

INTERVAL 是mysql间隔值,用法为INTERVAL expr unitINTERVAL 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切换到想要应用的数据库,不然存储过程会应用到默认数据库中code

查看以及使用存储过程

查看存储过程事件

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

使用存储过程it

call del_data()

写一个事件

开启事件调度器event

SET GLOBAL event_scheduler = ON;

建立事件table

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

从明天的零点开始,每隔一天执行del_data存储过程

相关文章
相关标签/搜索