rake db:seed не работает

Я использую hstore для проекта, и у меня есть файл миграции:

class CreateShippingCategories < ActiveRecord::Migration
  def change
    create_table :shipping_categories do |t|
      t.string  :name
      t.hstore  :size
      t.integer :price_transport
      t.integer :price_storage
      t.timestamps
    end
  end
end

По умолчанию у меня есть 4 типа категорий, и я решил создать их в файле seed.rb следующим образом:

shipping_categories = [
  [ "Small", {L: 40, B: 30, H: 22}, 700, 100],
  [ "Medium", {L: 60, B: 40, H: 32}, 900, 400],
  [ "Large", {L: 60, B: 52, H: 140}],
  [ "XX Large", {L: 200, B: 50, H: 200}]
]

shipping_categories.each do |name, size, price_transport, price_storage|
  ShippingCategory.where(name: name, size: size, price_transport: price_transport, price_storage: price_storage).first_or_create
end

Но когда я пытаюсь запустить rake db:seed, я получаю эту ошибку:

rake aborted!
ActiveRecord::StatementInvalid: PG::UndefinedTable: ERROR:  missing FROM-clause entry for table "size"
LINE 1: ... WHERE "shipping_categories"."name" = 'Small' AND "size"."L"...
                                                         ^
: SELECT  "shipping_categories".* FROM "shipping_categories"  WHERE "shipping_categories"."name" = 'Small' AND "size"."L" = 40 AND "shipping_categories"."price_transport" = 700 AND "shipping_categories"."price_storage" = 100  ORDER BY "shipping_categories"."id" ASC LIMIT 1

Есть ли у кого-нибудь идеи, как решить эту проблему?


person Svyat Muzyka    schedule 15.08.2014    source источник


Ответы (1)


Проблема в том, как вы запрашиваете часть find файла find_or_create. Я подозреваю, что вы пытаетесь создать только ShippingCategory, если он не существует. Имя уникально? Если это так, вы можете сделать:

ShippingCategory.
  create_with(name: name, size: size, price_transport: price_transport, 
    price_storage: price_storage).
  find_or_create_by(name: name)

Дополнительные сведения см. в документации по find_or_create_by.

person Rob Di Marco    schedule 15.08.2014