2018-05-09 12:01:36 +05:30
|
|
|
# See http://doc.gitlab.com/ce/development/migration_style_guide.html
|
|
|
|
# for more information on how to write migrations for GitLab.
|
|
|
|
|
2019-02-15 15:39:39 +05:30
|
|
|
class AddPathIndexToRedirectRoutes < ActiveRecord::Migration[4.2]
|
2018-05-09 12:01:36 +05:30
|
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
|
|
|
|
# Set this constant to true if this migration requires downtime.
|
|
|
|
DOWNTIME = false
|
|
|
|
disable_ddl_transaction!
|
|
|
|
|
|
|
|
INDEX_NAME = 'index_redirect_routes_on_path_unique_text_pattern_ops'
|
|
|
|
|
|
|
|
# Indexing on LOWER(path) varchar_pattern_ops speeds up the LIKE query in
|
|
|
|
# RedirectRoute.matching_path_and_descendants
|
|
|
|
#
|
|
|
|
# This same index is also added in the `ReworkRedirectRoutesIndexes` so this
|
2019-12-21 20:55:43 +05:30
|
|
|
# is a no-op in most cases.
|
2018-05-09 12:01:36 +05:30
|
|
|
def up
|
2018-11-20 20:47:30 +05:30
|
|
|
disable_statement_timeout do
|
|
|
|
unless index_exists_by_name?(:redirect_routes, INDEX_NAME)
|
|
|
|
execute("CREATE UNIQUE INDEX CONCURRENTLY #{INDEX_NAME} ON redirect_routes (lower(path) varchar_pattern_ops);")
|
|
|
|
end
|
2018-05-09 12:01:36 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
|
|
|
# Do nothing in the DOWN. Since the index above is originally created in the
|
|
|
|
# `ReworkRedirectRoutesIndexes`. This migration wouldn't have actually
|
|
|
|
# created any new index.
|
|
|
|
end
|
|
|
|
end
|