summaryrefslogtreecommitdiff
path: root/lib/gitlab/database/subquery.rb
blob: 10971d2b27408a81890c42be428bca84e7939fde (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# frozen_string_literal: true

module Gitlab
  module Database
    module Subquery
      class << self
        def self_join(relation)
          t = relation.arel_table
          # Work around a bug in Rails 5, where LIMIT causes trouble
          # See https://gitlab.com/gitlab-org/gitlab-ce/issues/51729
          r = relation.limit(nil).arel
          r.take(relation.limit_value) if relation.limit_value
          t2 = r.as('t2')

          relation.unscoped.joins(t.join(t2).on(t[:id].eq(t2[:id])).join_sources.first)
        end
      end
    end
  end
end