From: simonbrandhof Date: Wed, 17 Nov 2010 15:23:59 +0000 (+0000) Subject: SONAR-1990 ORA-01795 when deleting orphan snapshots X-Git-Tag: 2.6~568 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=8f9bdaa97f447b0c2646ebceed8b371c9916a03e;p=sonarqube.git SONAR-1990 ORA-01795 when deleting orphan snapshots --- diff --git a/sonar-server/src/main/webapp/WEB-INF/db/migrate/152_delete_duplicated_lib_snapshots.rb b/sonar-server/src/main/webapp/WEB-INF/db/migrate/152_delete_duplicated_lib_snapshots.rb index 640ab06f4f5..c6c747532cd 100644 --- a/sonar-server/src/main/webapp/WEB-INF/db/migrate/152_delete_duplicated_lib_snapshots.rb +++ b/sonar-server/src/main/webapp/WEB-INF/db/migrate/152_delete_duplicated_lib_snapshots.rb @@ -47,7 +47,14 @@ class DeleteDuplicatedLibSnapshots < ActiveRecord::Migration def self.delete_snapshots(snapshots) if snapshots.size > 0 say_with_time "Deleting #{snapshots.size} orphan snapshots..." do - Snapshot.delete(snapshots.map{|s| s.id}) + sids=snapshots.map{|s| s.id} + page_size=950 + page_count=(sids.size/page_size) + page_count+=1 if (sids.size % page_size)>0 + page_count.times do |page_index| + page_sids=sids[page_index*page_size...(page_index+1)*page_size] + Snapshot.delete(page_sids) + end end end end