Make CopyStatusStats migration use batches of 1000 to avoid locks (#8256)

lolsob-rspec
Eugen Rochko 2018-08-18 03:44:50 +02:00 committed by GitHub
parent 6eca34ffb8
commit 9e5285bfb1
1 changed files with 10 additions and 7 deletions

View File

@ -3,13 +3,16 @@ class CopyStatusStats < ActiveRecord::Migration[5.2]
def up def up
safety_assured do safety_assured do
execute <<-SQL.squish Status.where.not(id: StatusStat.select('status_id')).select('id').find_in_batches do |statuses|
INSERT INTO status_stats (status_id, reblogs_count, favourites_count, created_at, updated_at) execute <<-SQL.squish
SELECT id, reblogs_count, favourites_count, created_at, updated_at INSERT INTO status_stats (status_id, reblogs_count, favourites_count, created_at, updated_at)
FROM statuses SELECT id, reblogs_count, favourites_count, created_at, updated_at
ON CONFLICT (status_id) DO UPDATE FROM statuses
SET reblogs_count = EXCLUDED.reblogs_count, favourites_count = EXCLUDED.favourites_count WHERE id IN (#{statuses.map(&:id).join(', ')})
SQL ON CONFLICT (status_id) DO UPDATE
SET reblogs_count = EXCLUDED.reblogs_count, favourites_count = EXCLUDED.favourites_count
SQL
end
end end
end end