gitlab-org--gitlab-foss/db/migrate/20170918222253_reorganize_deployments_indexes.rb
Yorick Peterse 05a8f401c2
Reorganize indexes for the "deployments" table
This removes the need for a default scope that adds a "WHERE project_id
= X" clause. This commit also includes an additional index for
Environment#last_deployment, ensuring this query uses just an index scan
instead of also applying a Filter.

Fixes https://gitlab.com/gitlab-org/gitlab-ce/issues/36877
2017-09-19 00:39:52 +02:00

28 lines
899 B
Ruby

# See http://doc.gitlab.com/ce/development/migration_style_guide.html
# for more information on how to write migrations for GitLab.
class ReorganizeDeploymentsIndexes < ActiveRecord::Migration
include Gitlab::Database::MigrationHelpers
DOWNTIME = false
disable_ddl_transaction!
def up
add_index_if_not_exists :deployments, [:environment_id, :iid, :project_id]
remove_index_if_exists :deployments, [:project_id, :environment_id, :iid]
end
def down
add_index_if_not_exists :deployments, [:project_id, :environment_id, :iid]
remove_index_if_exists :deployments, [:environment_id, :iid, :project_id]
end
def add_index_if_not_exists(table, columns)
add_concurrent_index(table, columns) unless index_exists?(table, columns)
end
def remove_index_if_exists(table, columns)
remove_concurrent_index(table, columns) if index_exists?(table, columns)
end
end