diff options
Diffstat (limited to 'lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb')
-rw-r--r-- | lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb b/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb new file mode 100644 index 00000000000..592ef3220ff --- /dev/null +++ b/lib/gitlab/background_migration/nullify_creator_id_column_of_orphaned_projects.rb @@ -0,0 +1,24 @@ +# frozen_string_literal: true + +module Gitlab + module BackgroundMigration + # A job to nullify `projects.creator_id` column of projects who creator + # does not exist in `users` table anymore. + class NullifyCreatorIdColumnOfOrphanedProjects < BatchedMigrationJob + scope_to ->(relation) do + relation.where.not(creator_id: nil) + .joins('LEFT OUTER JOIN users ON users.id = projects.creator_id') + .where(users: { id: nil }) + end + + operation_name :update_all + feature_category :projects + + def perform + each_sub_batch do |sub_batch| + sub_batch.update_all(creator_id: nil) + end + end + end + end +end |