rails query left joins includes active ruby-on-rails activerecord scope rails-activerecord

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])