zoukankan      html  css  js  c++  java
  • mysql定时删除数据

    删除三天前的数据的sql

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

    CURDATE() 返回当前日期

    CURNOW() 返回当前datetime

    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切换到想要应用的数据库,否则存储过程会应用到默认数据库中

    查看以及使用存储过程

    查看存储过程

    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()
    

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

  • 相关阅读:
    攻防世界 resver catch-me
    elf.h
    攻防世界 reverse 进阶 notsequence
    攻防世界 reverse 进阶 easyre-153
    攻防世界 reverse 进阶 APK-逆向2
    寒假训练 roarctf_2019_realloc_magic(1/250)
    寒假任务
    Main_arena与non_main_arena
    wdb2018_guess
    :: namespace using作用
  • 原文地址:https://www.cnblogs.com/luozx207/p/10607696.html
Copyright © 2011-2022 走看看