Ответ 1
Вам нужно добавить
has_many :entries
Для каждой из ваших моделей, поскольку опция: through указывает только вторую ассоциацию, которую она должна использовать для поиска другой стороны.
У меня проблемы с получением ассоциации has_many through
.
Я получаю это исключение:
Article.find(1).warehouses.build
ActiveRecord::HasManyThroughAssociationNotFoundError: Could not find the association :entries in model Article
Это используемые модели:
class Article < ActiveRecord::Base
has_many :warehouses, :through => :entries
end
class Warehouse < ActiveRecord::Base
has_many :articles, :through => :entries
end
class Entry < ActiveRecord::Base
belongs_to :article
belongs_to :warehouse
end
И это моя схема:
create_table "articles", :force => true do |t|
t.string "article_nr"
t.string "name"
t.integer "amount"
t.string "warehouse_nr"
t.datetime "created_at"
t.datetime "updated_at"
t.integer "unit"
end
create_table "entries", :force => true do |t|
t.integer "warehouse_id"
t.integer "article_id"
t.integer "amount"
end
create_table "warehouses", :force => true do |t|
t.string "warehouse_nr"
t.string "name"
t.integer "utilization"
t.datetime "created_at"
t.datetime "updated_at"
end
Вам нужно добавить
has_many :entries
Для каждой из ваших моделей, поскольку опция: through указывает только вторую ассоциацию, которую она должна использовать для поиска другой стороны.
@Meekohi Это означает, что у вас нет модели ввода. Я только что получил сообщение об ошибке, поэтому хотел указать его (не могу опубликовать его как комментарий из-за низкой репутации).
class Entry < ActiveRecord::Base
belongs_to :article
belongs_to :warehouse
end
Просто запустите
rails g model Entry
Вам нужно будет добавить
has_many :entries
Каждой модели и выше has_many: через, вот так:
class Article < ActiveRecord::Base
has_many :entries
has_many :warehouses, :through => :entries
end
class Warehouse < ActiveRecord::Base
has_many :entries
has_many :articles, :through => :entries
end
Более подробное руководство по обработке представлений и контроллеров https://kolosek.com/rails-join-table/