データベースには、時間の経過とともに古いデータが蓄積されることが多く、テーブルの肥大化やパフォーマンスの問題につながります。このようなデータを効率的に管理するために、MySQL には、クリーンアップ タスクを自動化するストアド プロシージャを作成する機能が用意されています。
次のストアド プロシージャは、7 より古い行を自動的に削除します。データベース内のすべてのテーブルからの日数:
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 ;
このストアド プロシージャは、データベース名を格納する変数を初期化し、最大削除します。日付、およびテーブル名のカンマ区切りのリスト。次に、ヘルパー関数 (execute_delete_query) を呼び出して、実際の削除を実行します。
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
ヘルパー関数execute_delete_queryは、テーブル名のリストと最大値の2つのパラメータを取ります。削除日。テーブル名を反復処理し、テーブル名ごとに削除クエリを作成し、準備されたステートメントを使用して実行します。削除された行の合計数が返されます。
毎日 00:00 にストアド プロシージャが自動的に実行されるようにスケジュールするには、次の手順に従います。
次の SQL を使用してイベントを作成しますステートメント:
CREATE EVENT delete_old_data_event ON SCHEDULE AT '00:00' EVERY 1 DAY DO CALL delete_old_data();
event_scheduler システム変数を ON に設定してイベント スケジューラを有効にします:
SET GLOBAL event_scheduler = ON;
この方法では、MySQL のストアド プロシージャ、イベント スケジューリング、およびヘルパー関数を使用して、データベースから古いデータを削除するための包括的で自動化されたソリューションを作成します。古いレコードを定期的に削除することで、データ コンプライアンスを確保しながらデータベースの効率とパフォーマンスを維持できます。
以上がMySQL で 7 日より古い行を自動的に削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。