Как заполнить таблицу соединений для отношений 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
отношения