Mysql
 sql >> Database >  >> RDS >> Mysql

Rails 3 - Carico desideroso di condizioni

Aggiungi una nuova associazione chiamata published_pages (a parte le tue attuali associazioni)

class Category

  has_many   :children,        :class_name => "Category", 
               :foreign_key => "parent_id"
  has_many   :published_pages, :class_name => "Page", 
               :conditions  => { :is_published => true }

end

Ora puoi ottenere tutte le categorie come segue:

self.categories.includes(:children, :published_pages)

Se sei interessato a scoprire perché il tuo approccio non ha funzionato, leggi la documentazione (scorri di 10-15 righe dopo il Eager loading of associations sezione). Ho incluso lo snippet pertinente di seguito:

Per caricare in modo ansioso le righe filtrate di un'associazione, utilizza un'associazione con condizioni:

class Post < ActiveRecord::Base
  has_many :approved_comments, :class_name => 'Comment', 
             :conditions => ['approved = ?', true]
end

Post.find(:all, :include => :approved_comments)