From 4b98e812b29e8f9bc11d2eaa4ad0ddd474caa9a6 Mon Sep 17 00:00:00 2001 From: Olaf Tomalka <olaf.tomalka@gmail.com> Date: Tue, 6 Sep 2016 11:53:34 +0200 Subject: [PATCH] Optimized event pruning query to avoid two queries. --- CHANGELOG | 3 +-- app/workers/prune_old_events_worker.rb | 13 +++++++++++-- 2 files changed, 12 insertions(+), 4 deletions(-) diff --git a/CHANGELOG b/CHANGELOG index 1d42acfe363..7eb535923a6 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -3,9 +3,8 @@ Please view this file on the master branch, on stable branches it's out of date. v 8.12.0 (unreleased) - Add ability to fork to a specific namespace using API. (ritave) - Cleanup misalignments in Issue list view !6206 - - Prune events older than 12 months. @ritave <olaf@tomalka.me> + - Prune events older than 12 months. (ritave) - Prepend blank line to `Closes` message on merge request linked to issue (lukehowell) - - Prune events older than 12 months. - Filter tags by name !6121 - Make push events have equal vertical spacing. - Add two-factor recovery endpoint to internal API !5510 diff --git a/app/workers/prune_old_events_worker.rb b/app/workers/prune_old_events_worker.rb index d75083f9ab1..5883cafe1d1 100644 --- a/app/workers/prune_old_events_worker.rb +++ b/app/workers/prune_old_events_worker.rb @@ -2,7 +2,16 @@ class PruneOldEventsWorker include Sidekiq::Worker def perform - # Contribution calendar shows maximum 12 months of events - Event.delete(Event.unscoped.where('created_at < ?', (12.months + 1.day).ago).limit(10_000).pluck(:id)) + # Contribution calendar shows maximum 12 months of events. + # Double nested query is used because MySQL doesn't allow DELETE subqueries + # on the same table. + Event.unscoped.where( + '(id IN (SELECT id FROM (?) ids_to_remove))', + Event.unscoped.where( + 'created_at < ?', + (12.months + 1.day).ago). + select(:id). + limit(10_000)). + delete_all end end -- GitLab