Sha256: 303906ffb35e86b6baeab73548354e097c46328b42976279f40f518fadd3de97

Contents?: true

Size: 1007 Bytes

Versions: 14

Compression:

Stored size: 1007 Bytes

Contents

# This migration comes from spree (originally 20131211192741)
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

14 entries across 14 versions & 7 rubygems

Version Path
spree_weight_calculator-0.1.0 test/dummy/db/migrate/20160723192543_unique_shipping_method_categories.spree.rb
spree_order_reporting-0.0.3 spec/dummy/db/migrate/20160708163140_unique_shipping_method_categories.spree.rb
spree_order_reporting-0.0.2 spec/dummy/db/migrate/20160707103464_unique_shipping_method_categories.spree.rb
spree_order_reporting-0.0.1 spec/dummy/db/migrate/20160706112416_unique_shipping_method_categories.spree.rb
sprangular-0.1.0 spec/dummy/db/migrate/20140814105742_unique_shipping_method_categories.spree.rb
sprangular-0.0.1 spec/dummy/db/migrate/20140814105742_unique_shipping_method_categories.spree.rb
spree_mercado_pago-0.2.3 spec/dummy/db/migrate/20141204014735_unique_shipping_method_categories.spree.rb
spree_mercado_pago-0.2.2 spec/dummy/db/migrate/20141204014735_unique_shipping_method_categories.spree.rb
spree_mercado_pago-0.2.1 spec/dummy/db/migrate/20141112193518_unique_shipping_method_categories.spree.rb
spree_mercado_pago-0.2.0 spec/dummy/db/migrate/20141112193518_unique_shipping_method_categories.spree.rb
spree_mercado_pago_payment_method-0.2.0 spec/dummy/db/migrate/20141112193518_unique_shipping_method_categories.spree.rb
spree_bitpay-1.0.2 spec/dummy/db/migrate/20141002181315_unique_shipping_method_categories.spree.rb
bcms_spree-0.0.2 test/dummy/db/migrate/20140915222654_unique_shipping_method_categories.spree.rb
bcms_spree-0.0.1 test/dummy/db/migrate/20140915222654_unique_shipping_method_categories.spree.rb