Sha256: 3c804f28f5fee4af38e559ac05d2b171a83b959cae060bb43b6db248b398add0

Contents?: true

Size: 945 Bytes

Versions: 129

Compression:

Stored size: 945 Bytes

Contents

class UniqueShippingMethodCategories < ActiveRecord::Migration
  def change
    klass   = Spree::ShippingMethodCategory
    columns = %w[shipping_category_id shipping_method_id]

    say "Find duplicate #{klass} records"
    duplicates = klass.
      select((columns + %w[COUNT(*)]).join(',')).
      group(columns.join(',')).
      having('COUNT(*) > 1').
      map { |row| row.attributes.slice(*columns) }

    say "Delete all but the oldest duplicate #{klass} record"
    duplicates.each do |conditions|
      klass.where(conditions).order(:created_at).drop(1).each(&:destroy)
    end

    say "Add unique index to #{klass.table_name} for #{columns.inspect}"
    add_index klass.table_name, columns, unique: true, name: 'unique_spree_shipping_method_categories'

    say "Remove redundant simple index on #{klass.table_name}"
    remove_index klass.table_name, name: 'index_spree_shipping_method_categories_on_shipping_category_id'
  end
end

Version data entries

129 entries across 129 versions & 3 rubygems

Version Path
goca-spree-core-3.1.14.rails.5.0.1 db/migrate/20131211192741_unique_shipping_method_categories.rb
goca-spree-core-3.1.14.rails.5.0 db/migrate/20131211192741_unique_shipping_method_categories.rb
goca-spree-core-3.1.15.rails.5.0 db/migrate/20131211192741_unique_shipping_method_categories.rb
goca-spree-core-3.1.15.pre.rails.pre.5.0 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.14 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.13 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.12 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.4.2 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.3.2 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.2.3 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.1.4 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.0.7 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.11 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.10 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.9 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.8 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.7 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.6 db/migrate/20131211192741_unique_shipping_method_categories.rb
solidus_core-1.4.1 db/migrate/20131211192741_unique_shipping_method_categories.rb
spree_core-3.1.5 db/migrate/20131211192741_unique_shipping_method_categories.rb