Рельсы включают в себя
У меня есть модель под названием "Автор". У автора много статей.
У статей есть область под названием .published, которая делает: where (опубликовано: true).
Я хочу загрузить автора с опубликованными статьями.
Я пробовал:
Author.includes(:articles.published).find(params[:author_id])
Но это вызывает ошибку: undefined метод "опубликован".
Любая идея?
Ответы
Ответ 1
Я думаю, что лучшим решением будет:
Author.includes(:articles).where(:articles=>{published: true}).find(params[:author_id])
Или вы можете создать область:
class Author < ActiveRecord::Base
scope :with_published_articles, -> { includes(:articles).where(articles: { published: true}) }
end
а потом:
Author.with_published_articles.find(params[:author_id].to_s)
Ответ 2
Я бы указал область действия Author
, называемую with_published_articles
следующим образом:
scope :with_published_articles, -> { joins(:articles).merge(Article.published) }
Это решит вашу проблему, чтобы также указать where(active: true)
в вашей модели Author
в случае, если поведение published
и Article
изменится в будущем.
Итак, теперь вы можете позвонить:
Author.with_published_articles.find(params[:author_id])
Ответ 3
Попробуйте этот код:
Author
.includes(:articles).where(published: true).references(:articles)
.find(params[:author_id])
Здесь вы можете найти более подробную информацию о примере выше:
включает api doc
Ответ 4
class Articles < ActiveRecord::Base
scope :published, -> { where(articles: {published: true}) }
end
class Author < ActiveRecord::Base
scope :with_published_articles, -> { joins(:articles).merge(Articles.published) }
end