Rails includes with scope

后端 未结 4 746
耶瑟儿~
耶瑟儿~ 2021-02-05 01:30

I have a model called Author. An author has many Articles. Articles have a scope called .published that does: where(published: true).

I want to load the author, with the

相关标签:
4条回答
  • 2021-02-05 01:51

    Using:

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

    Define a scope on Autor

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

    Or

    Author.joins(:articles).merge(Articles.published).find(params[:author_id])
    
    0 讨论(0)
  • 2021-02-05 01:57

    I think the best solution would be:

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

    Or you can create scope:

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

    and then:

    Author.with_published_articles.find(params[:author_id].to_s)
    
    0 讨论(0)
  • 2021-02-05 02:01

    I would specify a scope on the Author called with_published_articles like this:

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

    This will resolve your problem to also specify the where(active: true) on your Author model in case the published behaviour of and Article will change in the future.

    So now you can call:

    Author.with_published_articles.find(params[:author_id])
    
    0 讨论(0)
  • 2021-02-05 02:02

    Try this code:

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

    Here you can find more information about the example above: includes api doc

    0 讨论(0)
提交回复
热议问题