我的两个模型用户和提交如下:
class User < ActiveRecord::Base
# Associations
has_many :submissions
accepts_nested_attributes_for :submissions
# Setup accessible (or protected) attributes for your model
attr_accessible :email,:name,:role,:submission_ids,:quotation_ids,:submissions_attributes
validates :email,:presence => {:message => "Please enter a valid email address" }
validates :email,:uniqueness => { :case_sensitive => false }
end
class Submission < ActiveRecord::Base
belongs_to :user
attr_accessible :due_date,:text,:title,:word_count,:work_type,:rush,:user,:notes
validates :work_type,:presence => true
validates :text,:length => { :minimum => 250 }
validates :word_count,:numericality => { :only_integer => true }
end
我有一个表格收集这两个模型所需的数据.用户控制器:
def index
@user = User.new
@user.submissions.build
end
def create
@user = User.where(:email => params[:user][:email]).first_or_create(params[:user])
if @user
redirect_to :root
else
render 'pages/index'
end
end
我想要做的是首先通过提交的电子邮件检查用户是否已经存在于系统中.如果是,那么我想为该用户创建提交.否则,请同时创建用户和提交.
我对如何使用first_or_create方法执行此操作感到困惑.
任何帮助赞赏.
解决方法
first_or_create
accepts a block.所以你可以这样做:
@user = User.where(:email => params[:user][:email]).first_or_create do |user| # This block is called with a new user object with only :email set # Customize this object to your will user.attributes = params[:user] # After this,first_or_create will call user.create,so you don't have to end
