sql >> Databáze >  >> RDS >> Mysql

Kolejnice 3 – Dychtivé nakládání s podmínkami

Přidejte nové přidružení s názvem published_pages (kromě vašich současných přidružení)

class Category

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

end

Nyní můžete získat všechny kategorie následovně:

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

Pokud vás zajímá, proč váš přístup nefungoval, přečtěte si dokumentaci k Rails (Posuňte se o 10–15 řádků po Eager loading of associations sekce). Níže uvádíme příslušný úryvek:

Chcete-li dychtivě načíst filtrované řádky přidružení, použijte přidružení s podmínkami:

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

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



  1. MySQL – nejlepší metoda pro zpracování těchto hierarchických dat?

  2. Nejlepší způsob, jak archivovat živou databázi MySQL

  3. Zpětné inženýrství databáze MySQL pomocí MySQL Workbench

  4. Vyberte poslední řádek pomocí GROUP BY v MySQL