38 lines
1.0 KiB
Ruby
38 lines
1.0 KiB
Ruby
# See http://doc.gitlab.com/ce/development/migration_style_guide.html
|
|
# for more information on how to write migrations for GitLab.
|
|
|
|
class AddIndexOnEventsProjectIdId < ActiveRecord::Migration
|
|
include Gitlab::Database::MigrationHelpers
|
|
|
|
DOWNTIME = false
|
|
|
|
COLUMNS = %i[project_id id].freeze
|
|
TABLES = %i[events events_for_migration].freeze
|
|
|
|
disable_ddl_transaction!
|
|
|
|
def up
|
|
TABLES.each do |table|
|
|
add_concurrent_index(table, COLUMNS) unless index_exists?(table, COLUMNS)
|
|
|
|
# We remove the index _after_ adding the new one since MySQL doesn't let
|
|
# you remove an index when a foreign key exists for the same column.
|
|
if index_exists?(table, :project_id)
|
|
remove_concurrent_index(table, :project_id)
|
|
end
|
|
end
|
|
end
|
|
|
|
def down
|
|
TABLES.each do |table|
|
|
unless index_exists?(table, :project_id)
|
|
add_concurrent_index(table, :project_id)
|
|
end
|
|
|
|
unless index_exists?(table, COLUMNS)
|
|
remove_concurrent_index(table, COLUMNS)
|
|
end
|
|
end
|
|
end
|
|
end
|