Fix n+1 query in settings migration (#24783)

th-downstream
Eugen Rochko 2 years ago committed by GitHub
parent 140e0f0bb7
commit d548faf693

@ -59,9 +59,11 @@ class MoveUserSettings < ActiveRecord::Migration[6.1]
end end
def up def up
User.find_each do |user| User.find_in_batches do |users|
previous_settings = LegacySetting.where(thing_type: 'User', thing_id: user.id).index_by(&:var) previous_settings_for_batch = LegacySetting.where(thing_type: 'User', thing_id: users.map(&:id)).group_by(&:thing_id)
users.each do |user|
previous_settings = previous_settings_for_batch[user.id]&.index_by(&:var) || {}
user_settings = {} user_settings = {}
MAPPING.each do |legacy_key, new_key| MAPPING.each do |legacy_key, new_key|
@ -81,6 +83,7 @@ class MoveUserSettings < ActiveRecord::Migration[6.1]
user.update_column('settings', Oj.dump(user_settings)) # rubocop:disable Rails/SkipsModelValidations user.update_column('settings', Oj.dump(user_settings)) # rubocop:disable Rails/SkipsModelValidations
end end
end end
end
def down; end def down; end
end end

Loading…
Cancel
Save