sql >> Base de Datos >  >> RDS >> Mysql

Rieles 3:carga ansiosa con condiciones

Agrega una nueva asociación llamada published_pages (aparte de sus asociaciones actuales)

class Category

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

end

Ahora puede obtener todas las categorías de la siguiente manera:

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

Si está interesado en saber por qué su enfoque no funcionó, lea la documentación (Desplácese 10-15 líneas después de Eager loading of associations sección). He incluido el fragmento relevante a continuación:

Para cargar rápidamente las filas filtradas de una asociación, use una asociación con condiciones:

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

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