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