web-dev-qa-db-fra.com

Rails inclut avec la portée

J'ai un modèle appelé Author. Un auteur a de nombreux articles. Les articles ont une portée appelée .published qui fait: où (publié: vrai).

Je veux charger l'auteur, avec les articles publiés. J'ai essayé:

Author.includes(:articles.published).find(params[:author_id])

Mais cela jette une erreur: méthode non définie "publiée". Une idée?

26
MonsieurNinja

Je pense que la meilleure solution serait:

Author.includes(:articles).where(:articles=>{published: true}).find(params[:author_id])

Ou vous pouvez créer une portée:

class Author < ActiveRecord::Base 
    scope :with_published_articles, -> { includes(:articles).where(articles: { published: true}) }
end

puis:

Author.with_published_articles.find(params[:author_id].to_s)
37
NikCasper

Je voudrais spécifier une portée sur le Author appelée with_published_articles Comme ceci:

scope :with_published_articles, -> { joins(:articles).merge(Article.published) }

Cela résoudra votre problème en spécifiant également la where(active: true) sur votre modèle Author au cas où le comportement published de et Article changerait à l'avenir.

Alors maintenant, vous pouvez appeler:

Author.with_published_articles.find(params[:author_id])
18
Manuel van Rijn

Essayez ce code:

Author
  .includes(:articles).where(published: true).references(:articles)
  .find(params[:author_id])

Ici vous pouvez trouver plus d'informations sur l'exemple ci-dessus: inclut l'api doc

2
max_spy

En utilisant:

class Articles < ActiveRecord::Base 
    scope :published, -> { where(articles: {published: true}) }
end

Définir une portée sur Autor

class Author < ActiveRecord::Base 
    scope :with_published_articles, -> { joins(:articles).merge(Articles.published) }
end

Ou

Author.joins(:articles).merge(Articles.published).find(params[:author_id])
1
Wagner Caixeta