Welcome to mirror list, hosted at ThFree Co, Russian Federation.

database_helpers.rb « import « gitlab « lib - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 5b3f30d894a436b3bf5386a83ba409f57dea3126 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# frozen_string_literal: true

module Gitlab
  module Import
    module DatabaseHelpers
      # Inserts a raw row and returns the ID of the inserted row.
      #
      # attributes - The attributes/columns to set.
      # relation - An ActiveRecord::Relation to use for finding the ID of the row
      #            when using MySQL.
      # rubocop: disable CodeReuse/ActiveRecord
      def insert_and_return_id(attributes, relation)
        # We use bulk_insert here so we can bypass any queries executed by
        # callbacks or validation rules, as doing this wouldn't scale when
        # importing very large projects.
        result = Gitlab::Database
                 .bulk_insert(relation.table_name, [attributes], return_ids: true)

        # MySQL doesn't support returning the IDs of a bulk insert in a way that
        # is not a pain, so in this case we'll issue an extra query instead.
        result.first ||
          relation.where(iid: attributes[:iid]).limit(1).pluck(:id).first
      end
      # rubocop: enable CodeReuse/ActiveRecord
    end
  end
end