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.
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.
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.
Untuk menjadualkan prosedur tersimpan berjalan secara automatik setiap hari pada jam 00:00, ikut langkah berikut:
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();
Dayakan penjadual acara dengan menetapkan pembolehubah sistem event_scheduler kepada HIDUP:
SET GLOBAL event_scheduler = ON;
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!