Подтвердить что ты не робот

Rails: HasManyThroughAssociationNotFoundError

У меня проблемы с получением ассоциации 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
4b9b3361

Ответ 1

Вам нужно добавить

has_many :entries

Для каждой из ваших моделей, поскольку опция: through указывает только вторую ассоциацию, которую она должна использовать для поиска другой стороны.

Ответ 2

@Meekohi Это означает, что у вас нет модели ввода. Я только что получил сообщение об ошибке, поэтому хотел указать его (не могу опубликовать его как комментарий из-за низкой репутации).

class Entry < ActiveRecord::Base
  belongs_to :article
  belongs_to :warehouse
end

Просто запустите

rails g model Entry

Ответ 3

Вам нужно будет добавить

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/