开发者

Rails DB Seeding

开发者 https://www.devze.com 2023-01-05 22:17 出处:网络
For some reason, the food_id field in \'ratings\' isn\'t populating when I run the seed.rb file below.Can somebody help me figure out why?

For some reason, the food_id field in 'ratings' isn't populating when I run the seed.rb file below. Can somebody help me figure out why?

Seed file contains the following lines:

Food.create(:id => 1, :description => 'Stonyfield Farm Yomommy 4oz. Strawberry')
OverallRating.create(:score => 0, :count => 1, :food_id => 1)

Code for Food and Rating are as follows: class OverallRating < Rating b开发者_如何学JAVAelongs_to :food end

class Food < ActiveRecord::Base
   has_one :overall_rating
end

class Rating < ActiveRecord::Base
  belongs_to :food
end

The rating migration file is as follows:

class CreateRatings < ActiveRecord::Migration
  def self.up
    create_table :ratings do |t|
      t.integer :food_id
      t.integer :count
      t.decimal :score
      t.string :type
      t.timestamps
    end
  end

  def self.down
    drop_table :ratings
  end
end


how are you invoking the seeds.rb file? You may have to do a rake db:seed


Is that really the actual code? I would guess you've got an attr_accessible or attr_protected declaration in Rating/OverallRating that is preventing the option from being set in the instantiated object.


Instead of hardcoding the id, try something like this:

food = Food.create(:description => 'blah')
food.create_overall_rating(:score => 0, :count => 1)

I just tried your exact method though, and it worked for me without a problem. So perhaps you have something else awry.

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号