Skip to content
Snippets Groups Projects

Replace foreign keys to use the partitioned table - V2

Merged Marius Bobin requested to merge re-enqueue-partitioned-fk-creation into master
Files
13
# frozen_string_literal: true
class ReplaceCiJobArtifactsForeignKeyV2 < Gitlab::Database::Migration[2.1]
include Gitlab::Database::MigrationHelpers::WraparoundAutovacuum
disable_ddl_transaction!
def up
return unless should_run?
add_concurrent_foreign_key :ci_job_artifacts, :p_ci_builds,
name: 'temp_fk_rails_c5137cb2c1_p',
column: [:partition_id, :job_id],
target_column: [:partition_id, :id],
on_update: :cascade,
on_delete: :cascade,
validate: false,
reverse_lock_order: true
prepare_async_foreign_key_validation :ci_job_artifacts,
name: 'temp_fk_rails_c5137cb2c1_p'
end
def down
return unless should_run?
unprepare_async_foreign_key_validation :ci_job_artifacts, name: 'temp_fk_rails_c5137cb2c1_p'
remove_foreign_key_if_exists :ci_job_artifacts, name: 'temp_fk_rails_c5137cb2c1_p'
end
private
def should_run?
can_execute_on?(:ci_job_artifacts, :ci_builds)
end
end
Loading