How to automatically delete records before a specified time in Mysql

How to automatically delete records before a specified time in Mysql

About Event: MySQL 5.1 began to introduce the concept of event. Event is a "time trigger", which is different from the event trigger of triggers. Event is similar to the Linux crontab scheduled task and is used for time triggering. By using it alone or calling a stored procedure, the related SQL statement or stored procedure is triggered at a specific point in time.

First, delete the SQL statements recorded 2 days ago (webserver_monitormemory is the table name, time is the time field):

delete From webserver_monitormemory where DATE(time) <= DATE(DATE_SUB(NOW(),INTERVAL 2 day));

Create a stored procedure:

DELIMITER //
CREATE PROCEDURE autodel()
  -> BEGIN
  -> delete From webserver_monitormemory where DATE(time) <= DATE(DATE_SUB(NOW(),INTERVAL 2 day));
  -> END
  -> //
DELIMITER ;

Create an event and customize the stored procedure that executes autodel every day:

CREATE EVENT `event_auto_del_memorydata`  
ON SCHEDULE EVERY 1 DAY STARTS '2017-11-20 00:00:00'  
ON COMPLETION NOT PRESERVE ENABLE DO CALL autodel();

There are 4 ways to start the event plan (scheduler). The key value 1 or ON means on; 0 or OFF means off:

SET GLOBAL event_scheduler = 1; 
SET @@global.event_scheduler = 1; 
SET GLOBAL event_scheduler = ON; 
SET @@global.event_scheduler = ON;

There are three ways to check whether the event plan (scheduler) is currently enabled:

SHOW VARIABLES LIKE 'event_scheduler';
SELECT @@event_scheduler;
SHOW PROCESSLIST;

Event opening and closing:

ALTER EVENT event_auto_del_memorydata ON COMPLETION PRESERVE ENABLE; //Enable an event ALTER EVENT event_auto_del_memorydata ON COMPLETION PRESERVE DISABLE; //Disable an event

This is the simplest but also the most important. We have to start the timer manually, otherwise it will not work.

ALTER EVENT event_time_clear_data ON 
COMPLETION PRESERVE ENABLE;

In addition, the code to turn off the timer is:

ALTER EVENT event_time_clear_data ON 
COMPLETION PRESERVE DISABLE;

Delete the stored procedure:

DROP PROCEDURE pro_clear_data;

Delete Event:

DROP EVENT IF EXISTS event_time_clear_data1

Summarize

The above is the operation method of automatically deleting records before a specified time under MySQL introduced by the editor. I hope it will be helpful to everyone. If you have any questions, please leave me a message and the editor will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!

You may also be interested in:
  • MySQL scheduled task example tutorial
  • How to implement Mysql scheduled tasks under Linux
  • Using MySQL in Windows: Implementing Automatic Scheduled Backups
  • Detailed explanation of MySQL database Event scheduled execution tasks
  • Commonplace talk about MySQL event scheduler (must read)
  • Detailed explanation of the usage of event in MySQL
  • Detailed explanation of mysql scheduled tasks (event events)

<<:  Nginx proxy axios request and precautions

>>:  Detailed explanation of Linux curl form login or submission and cookie usage

Recommend

Differences between MySQL CHAR and VARCHAR when storing and reading

Introduction Do you really know the difference be...

Common errors and solutions for connecting Navicat to virtual machine MySQL

Question 1 solve Start the service: service mysql...

In-depth understanding of mathematical expressions in CSS calc()

The mathematical expression calc() is a function ...

Summary of MySQL date and time functions (MySQL 5.X)

1. MySQL gets the current date and time function ...

How to configure MySQL scheduled tasks (EVENT events) in detail

Table of contents 1. What is an event? 2. Enable ...

Pure CSS to add style to select (no script) implementation

Change the default style of select, usually throug...

Design theory: On the issues of scheme, resources and communication

<br />This problem does not exist in many sm...

Summary of HTML formatting standards for web-based email content

1. Page requirements 1) Use standard headers and ...

MariaDB under Linux starts with the root user (recommended)

Recently, due to the need to test security produc...

Talk about important subdirectory issues in Linux system

/etc/fstab Automatically mount partitions/disks, ...

CentOS 6.5 i386 installation MySQL 5.7.18 detailed tutorial

Most people compile MySQL and put it in the syste...

Detailed explanation of Mysql's concurrent parameter adjustment

Table of contents Query cache optimization Overvi...