Rumah >pangkalan data >tutorial mysql >Bagaimana Secara Automatik Padam Baris Lebih Lama Daripada 7 Hari dalam MySQL?

Bagaimana Secara Automatik Padam Baris Lebih Lama Daripada 7 Hari dalam MySQL?

Susan Sarandon
Susan Sarandonasal
2024-12-07 00:42:11934semak imbas

How to Automatically Delete Rows Older Than 7 Days in MySQL?

Memadam Baris Lebih Lama daripada 7 Hari dalam MySQL Secara Automatik

Pengenalan

Pangkalan data sering mengumpul data usang dari semasa ke semasa, yang membawa kepada masalah jadual dan prestasi. Untuk mengurus data sedemikian dengan cekap, MySQL menyediakan keupayaan untuk mencipta prosedur tersimpan yang mengautomasikan tugas pembersihan.

Mencipta Prosedur Tersimpan untuk Memadam Data Lama

Prosedur tersimpan berikut akan memadamkan baris yang lebih lama daripada 7 secara automatik hari daripada semua jadual dalam pangkalan data:

DELIMITER $$

CREATE PROCEDURE delete_old_data()
BEGIN
  DECLARE tb_name VARCHAR(255);
  DECLARE max_date DATE;
  
  SET max_date = DATE_SUB(NOW(), INTERVAL 7 DAY);
  
  SET tb_name = (
    SELECT GROUP_CONCAT(TABLE_NAME)
    FROM INFORMATION_SCHEMA.TABLES
    WHERE TABLE_SCHEMA = DATABASE()
  );
  
  CALL execute_delete_query(tb_name, max_date);
END $$

DELIMITER ;

Prosedur tersimpan ini memulakan pembolehubah untuk menyimpan pangkalan data nama, tarikh pemadaman maksimum dan senarai nama jadual yang dipisahkan koma. Ia kemudian memanggil fungsi pembantu (execute_delete_query) untuk melaksanakan pemadaman sebenar.

Fungsi Pembantu untuk Memadam

CREATE FUNCTION execute_delete_query(tb_names VARCHAR(255), max_date DATE)
RETURNS INTEGER
BEGIN
  DECLARE tb_array [] VARCHAR(255);
  SET tb_array = SPLIT_STR(tb_names, ',');
  
  DECLARE i INT DEFAULT 1;
  DECLARE total_deleted INT DEFAULT 0;
  
  WHILE i <= SIZE(tb_array) DO
    SET @sql = CONCAT('DELETE FROM ', tb_array[i], ' WHERE update_timestamp < ''', max_date, ''');
    
    PREPARE stmt FROM @sql;
    EXECUTE stmt;
    SET total_deleted = total_deleted + ROW_COUNT();
    DEALLOCATE PREPARE stmt;
    
    SET i = i + 1;
  END WHILE;
  
  RETURN total_deleted;
END

Fungsi helper execute_delete_query mengambil dua parameter: senarai nama jadual dan maksimum tarikh pemadaman. Ia berulang melalui nama jadual, membina pertanyaan pemadaman untuk setiap satu, dan melaksanakannya menggunakan pernyataan yang disediakan. Jumlah bilangan baris yang dipadam dikembalikan.

Menjadualkan Prosedur Tersimpan

Untuk menjadualkan prosedur tersimpan berjalan secara automatik setiap hari pada jam 00:00, ikut langkah berikut:

  1. Buat acara menggunakan SQL berikut pernyataan:

    CREATE EVENT delete_old_data_event
    ON SCHEDULE AT '00:00' EVERY 1 DAY
    DO
    CALL delete_old_data();
  2. Dayakan penjadual acara dengan menetapkan pembolehubah sistem event_scheduler kepada HIDUP:

    SET GLOBAL event_scheduler = ON;
  3. Sahkan bahawa acara dijadualkan dengan berjalan TUNJUKKAN ACARA kenyataan.

Kesimpulan

Kaedah ini menggunakan prosedur tersimpan MySQL, penjadualan acara dan fungsi pembantu untuk mencipta penyelesaian yang komprehensif dan automatik untuk memadamkan data usang daripada pangkalan data. Dengan kerap mengalih keluar rekod lama, anda boleh mengekalkan kecekapan dan prestasi pangkalan data anda sambil memastikan pematuhan data.

Atas ialah kandungan terperinci Bagaimana Secara Automatik Padam Baris Lebih Lama Daripada 7 Hari dalam MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn