是否可以制作一个每晚11点运行的存储过程,如果过去六个月修改了任何记录,则检查表。如果过去六个月修改了某些记录,我必须从表中删除它。这必须在不使用任何外部语言的情况下自动运行。
答案 0 :(得分:14)
CREATE EVENT IF NOT EXISTS `my_old_data_cleaner_event`
ON SCHEDULE EVERY 23 DAY_HOUR
COMMENT 'Clean up Service Start at 11:00PM daily!'
DO DELETE FROM my_table WHERE created_date < (NOW() - INTERVAL 1 MONTH);
存储过程的OR。
CREATE EVENT IF NOT EXISTS `my_old_data_cleaner_event`
ON SCHEDULE EVERY 23 DAY_HOUR
DO CALL my_sp_cleanup_old_data();
答案 1 :(得分:3)
答案 2 :(得分:0)
创建如下所示的活动
CREATE EVENT e_daily
ON SCHEDULE
EVERY 1 DAY
DO
BEGIN
DELETE FROM tableA WHERE DATE(`yourtimestamp`) <(CURDATE() - INTERVAL 6 MONTHS);
END
答案 3 :(得分:0)
您还可以编写一个用Python,Perl,PHP等处理数据的脚本。
之后,只需使用crontab -e
设置cron条目并添加以下行:
0 23 * * * /path/to/my/script.pl 2>&1 >/dev/null
如果您未指定2>&1 >/dev/null
,您将收到包含执行结果的电子邮件。