通过rails中的单个对象在数据库表中提交多个条目

时间:2013-07-27 11:37:28

标签: ruby-on-rails

我是rails的新手,并且在最近两天遇到了这个问题 我有一个student&student_parent模型,他们有一个一对多关系我希望通过一个对象从表单到数据来构建数据库属性。

控制器的方法

def new
    @student = Student.new
    1.times{ @student.student_parents.build }
    .....
    .....
end

创建方法: -

def create
    @student = Student.new(params[:student])
    respond_to do |format|
        if @student.save
            format.html { redirect_to Student, notice: 'Student was successfully created.' }
            format.json { render json: @student, status: :created, location: @student }
        else
            format.html { render action: "new" }
            format.json { render json: @student.errors, status: :unprocessable_entity }
        end
    end
end

型号: -

class Student < ActiveRecord::Base

    include ErrorMessages

    belongs_to  :user
    has_many :student_parents

    attr_accessible :birth_date, :blood_group, :first_name, :gender, :last_name, :middle_name,
                  :school_name, :student_rollno, :email, :user_id, :student_parents_attributes

    accepts_nested_attributes_for :student_parents
end

表格: -

<%= simple_form_for @student, :html => { :class => 'form-horizontal' } do |f| %>
 <div class="row-fluid">
  <div class="span3">
    <%= f.label :first_name, :class => 'control-label',:required => true %>
    <%= f.text_field :first_name %>
  </div>
  <div class="span3">
    <%= f.label :middle_name, :class => 'control-label'%>
    <%= f.text_field :middle_name %>
  </div>
  <div class="span3">
    <%= f.label :last_name, :class => 'control-label',:required => true %>
    <%= f.text_field :last_name %>
  </div>
</div> &nbsp;

<div class="control-group">
  <label  class = "control-label"> Email </label>
  <div class="controls">
    <%= f.text_field :email, :class => 'text_field'  %>
  </div>
</div>

<div class="control-group">
  <label  class = "control-label"> Birth Date <abbr title="required">*</abbr></label>
  <div class="controls">
    <%= f.text_field :birth_date, :class => 'text_field' ,'data-behaviour' => 'datepicker' %>
  </div>
</div>

<% model_class = StudentParent %>
  <div class="page-header">
    <h4> Parent  Information</h4>
  </div>

<%= f.fields_for :student_parents  do |student_parent| %>
  <div class="row-fluid">

    <!--<div class="span9">-->

       <h5> Father Name </h5>

       <div class="span3">
          <%= student_parent.label :first_name, :class => 'control-label',:required => true %>
          <%= student_parent.text_field :first_name %>
       </div>

       <div class="span3">
          <%= student_parent.label :middle_name, :class => 'control-label'%>
          <%= student_parent.text_field :middle_name %>
       </div>

       <div class="span3">
          <%= student_parent.label :last_name, :class => 'control-label',:required => true %>
          <%= student_parent.text_field :last_name %>
       </div>

  </div> &nbsp;

    <div class="row-fluid">

      <h5> Mother Name </h5>

      <div class="span3">
        <%= student_parent.label :first_name, :class => 'control-label',:required => true %>
        <%= student_parent.text_field :first_name %>
      </div>

      <div class="span3">
        <%= student_parent.label :middle_name, :class => 'control-label'%>
        <%= student_parent.text_field :middle_name %>
      </div>

      <div class="span3">
        <%= student_parent.label :last_name, :class => 'control-label',:required => true %>
        <%= student_parent.text_field :last_name %>
      </div>

    </div> &nbsp;

<% end %>

<div class="form-actions">
  <%= f.button :submit, :class => 'btn-primary' %>
  <%= link_to t('.cancel', :default => t("helpers.links.cancel")),
              students_path, :class => 'btn' %>
</div>

提交时,只在学生表中构建学生信息,在 student_parent 表中创建母亲信息。但它错过了父母信息。

0 个答案:

没有答案