ruby on rails - query - Carriles incluidos con alcance.
rails sql query (3)
Tengo un modelo llamado Autor. Un autor tiene muchos artículos. Los artículos tienen un alcance llamado .published que hace: donde (publicado: verdadero).
Quiero cargar al autor, con los artículos publicados. Lo intenté:
Author.includes(:articles.published).find(params[:author_id])
Pero eso arroja un error: método indefinido ''publicado''. ¿Alguna idea?
Creo que la mejor solución sería:
Author.includes(:articles).where(:articles=>{published: true}).find(params[:author_id])
O puedes crear alcance:
class Author < ActiveRecord::Base
scope :published_articles, -> { includes(:articles).where(articles: { published: true}) }
end
y entonces:
Author.published_articles.find(params[:author_id].to_s)
Prueba este código:
Author
.includes(:articles).where(published: true).references(:articles)
.find(params[:author_id])
Aquí puede encontrar más información sobre el ejemplo anterior: incluye api doc
Yo especificaría un alcance en el Author
llamado with_published_articles
como este:
scope :with_published_articles, -> { joins(:articles).merge(Article.published) }
Esto resolverá su problema para especificar también where(active: true)
en su modelo de Author
en caso de que el comportamiento published
y el Article
cambien en el futuro.
Así que ahora puedes llamar:
Author.with_published_articles.find(params[:author_id])