mirror of
https://github.com/mastodon/mastodon.git
synced 2024-10-21 01:55:41 +09:00
25 lines
897 B
Ruby
25 lines
897 B
Ruby
# frozen_string_literal: true
|
|
|
|
class AddPrimaryKeyToStatusesTagsJoinTable < ActiveRecord::Migration[6.1]
|
|
disable_ddl_transaction!
|
|
|
|
def up
|
|
ActiveRecord::Base.transaction do
|
|
safety_assured do
|
|
execute 'ALTER TABLE statuses_tags ADD PRIMARY KEY USING INDEX index_statuses_tags_on_tag_id_and_status_id'
|
|
|
|
# Rename for consistency as the primary key's name is not represented in db/schema.rb
|
|
execute 'ALTER INDEX index_statuses_tags_on_tag_id_and_status_id RENAME TO statuses_tags_pkey'
|
|
end
|
|
end
|
|
end
|
|
|
|
def down
|
|
safety_assured do
|
|
# I have found no way to demote the primary key to an index, instead, re-create the index
|
|
execute 'CREATE UNIQUE INDEX CONCURRENTLY index_statuses_tags_on_tag_id_and_status_id ON statuses_tags (tag_id, status_id)'
|
|
execute 'ALTER TABLE statuses_tags DROP CONSTRAINT statuses_tags_pkey'
|
|
end
|
|
end
|
|
end
|