Mysql
 sql >> Base de Dados >  >> RDS >> Mysql

Trilhos 3 - Carregamento ansioso com condições


Adicione uma nova associação chamada published_pages (além de suas associações atuais)
class Category

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

end

Agora você pode obter todas as categorias da seguinte forma:
self.categories.includes(:children, :published_pages)

Se você estiver interessado em saber por que sua abordagem não funcionou, leia a documentação (role de 10 a 15 linhas após o Eager loading of associations seção). Incluí o trecho relevante abaixo:

Para carregar antecipadamente as linhas filtradas de uma associação, use uma associação com condições:
class Post < ActiveRecord::Base
  has_many :approved_comments, :class_name => 'Comment', 
             :conditions => ['approved = ?', true]
end

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