Как заполнить таблицу соединений для отношений HABTM Rails 3, postgresql

Поэтому после долгого и напряженного поиска информации, которая может нам помочь, нам было трудно найти ответ, с которым мы могли бы работать.

Наша проблема в том, что у нас есть две таблицы, объединенные через отношения HABTM, которые называются Школы и Организации. Сначала создается школа, а затем организация берет список школ, позволяет пользователю выбрать одну, а затем заполняет третью таблицу OrganizationsSchools как school_id, так и organization_id.

Модели для этих трех являются следующими: Модель школы:

class School < ActiveRecord::Base
  has_and_belongs_to_many :organizations, :join_table => 'organizations_schools'
  attr_accessible :name
  validates :name, :presence => true
end

Модель организации:

class Organization < ActiveRecord::Base
  has_many :materials
  has_many :users
  has_and_belongs_to_many :causes
  has_and_belongs_to_many :schools, :join_table => 'organizations_schools'
  attr_accessible :name, :unlogged_books_num, :id

  validates :name, :presence => true
end

Форма для организаций:

<%= form_for(@organization) do |f| %>
  <% if @organization.errors.any? %>
     <div id="error_explanation">
      <h2><%= pluralize(@organization.errors.count, "error") %> prohibited this organization from being saved:</h2>

      <ul>
      <% @organization.errors.full_messages.each do |msg| %>
        <li><%= msg %></li>
      <% end %>
      </ul>
    </div>
  <% end %>


<% @schools = School.all %>
  <div class="field">
    <%= f.label :name %><br />
    <%= f.text_field :name %>
  </div>
  <div class="field">
    <%= f.label :unlogged_books_num %><br />
    <%= f.number_field :unlogged_books_num %>
  </div>
  <div class="field">
    <%= f.label 'School' %><br />
    <% school_id = nil %>
    <%= collection_select(nil, school_id, @schools, :id, :name) %>  
  </div>
  <div class="actions">
    <%= f.submit %>
  </div>
<% end %>

И, наконец, функция создания в нашем контроллере организаций

class OrganizationsController < ApplicationController
  .
  .
  .
  def create
    @organization = Organization.new(params[:organization])
    org_id = @organization.id
    school_id = @organization.school_id
    @org_school = OrganizationsSchool.create(:organization_id => org_id, :school_id => school_id)

    respond_to do |format|
      if @organization.save
        format.html { redirect_to @organization, notice: 'Organization was successfully created.' }
        format.json { render json: @organization, status: :created, location: @organization }
      else
        format.html { render action: "new" }
        format.json { render json: @organization.errors, status: :unprocessable_entity }
      end
    end
  end
end

Все остальные функции в нашем контроллере создаются без перерыва. Пожалуйста, также знайте, что я не самый лучший в базах данных, и хотя я знаком с рельсами, я не очень разбираюсь в том, как правильно его использовать.

1 ответ

Решение

В has_and_belongs_to_many не будет поля school_id для Organization. Похоже, что вы действительно хотите:

class Organization < ActiveRecord::Base
  belongs_to :school
  ...
end

class School < ActiveRecord::Base
  has_many :organizations
end

если вы действительно хотите HABTM, то вы можете написать:

@organization.schools << School.find school_id

РЕДАКТИРОВАТЬ: Очевидно, ваш код контроллера потребует дополнительных изменений, если вы перешли на has_many отношения

Другие вопросы по тегам