我正试图用一个简单的种子文件填充我的SQLite3数据库,该文件应该在Film表中创建一堆电影条目,然后为存储在comments表中的电影创建一些注释。
formats = %w(Beta VHS IMAX HD SuperHD 4K DVD BlueRay)
30.times do
film = Film.create(title: "#{Company.bs}",
director: "#{Name.name}",
description: Lorem.paragraphs.join("<br/>").html_safe,
year: rand(1940..2015),
length: rand(20..240),
format: formats[rand(formats.length)]
)
film.save
(rand(0..10)).times do
film.comments.create( author: "#{Name.name}",
title: "#{Company.bs}",
content: Lorem.sentences(3).join("<br/>").html_safe,
rating: rand(1..5)
)
end
end
一旦我执行rake db:seed,我不可避免地会得到错误
ActiveRecord::RecordNotSaved:除非父项已保存,否则无法调用create
并且没有记录被添加到电影或评论
我的film.rb文件是
class Film < ActiveRecord::Base
has_many :comments
validates_presence_of :title, :director
validates_length_of :format, maximum: 5, minimum:3
validates_numericality_of :year, :length, greater_than: 0
validates_uniqueness_of :title
paginates_per 4
end
使用从"格式"列表中选择的格式创建电影时,"格式"的长度限制会引发错误
ActiveRecord::RecordNotSaved:除非父项已保存,否则无法调用create
当您试图保存子关联(注释),但父关联(影片)尚未保存时,会发生这种情况。
似乎未保存film
。从代码中可以看出,film = Film.create(...)
验证失败,因此film.comments.create(..)
无法继续。在不知道哪些验证失败的情况下,我只能说这些。
我建议在seeds.rb中到处使用create!(...)
。如果记录无效,bang版本将引发异常,并有助于防止静默失败。