【发布时间】:2011-05-26 12:02:40
【问题描述】:
有一段时间我陷入了这个问题。我正在尝试通过一个表单传递 3 个 ID 以将数据保存在我的数据库中。
def new
@person = Person.find(params[:person])
@honored = Person.find(params[:honored])
@group = Group.find(params[:group_id])
@honor = Honor.new
end
def create
@person = Person.find(current_person)
@honor = Honor.create(:group => Group.find(params[:group_id]),
:person => Person.find(params[:person]),
:honored => Person.find(params[:honored]))
if @honor.valid?
flash[:success] = "Honor created."
redirect_to (:back)
else
redirect_to (:back)
end
end
在我看来,我调用了new 方法:
<% @asked_groupmembership.each do |agm| %>
<%= link_to "Create Honor", new_honor_path(:group_id => @group.id, :person => current_person.id,
:honored => agm.member.id) %>
我的表格:
<% form_for @honor do |f| %>
<%= f.hidden_field :group_id, :value => @group.id %>
<%= f.hidden_field :person, :value => current_person.id %>
<%= f.hidden_field :honored, :value => @honored.id %>
<div class="field">
<%= f.label :texto %><br />
<%= f.text_field :texto %>
</div>
当我单击提交按钮时,我收到此错误:
Couldn't find Group without an ID
app/controllers/honors_controller.rb:22:in `create'
{"utf8"=>"✓",
"authenticity_token"=>"C7wofMY4VcyfdS10oc3iglex8nZVBMQ0Nh22nMiaOqs=",
"honor"=>{"group_id"=>"39",
"person"=>"2",
"honored"=>"44",
...
},
"commit"=>"Insert"}
我该如何解决这个问题? 谢谢。
##EDITED##
class Honor < ActiveRecord::Base
belongs_to :person, :class_name => 'Person', :foreign_key => "person_id"
belongs_to :honored, :class_name => 'Person', :foreign_key => "honored_id"
belongs_to :group, :class_name => 'Group', :foreign_key => "group_id"
【问题讨论】:
标签: ruby-on-rails ruby-on-rails-3 forms