Rails 3:查找具有parent_categories和parent_categories的所有类别

时间:2013-11-05 20:41:04

标签: ruby-on-rails

我有一个复杂的Category模型,它有parent_categories(它们本身就是类别)。我想创建一个范围来查找所有第三级别类别(父母有父母的类别)。

class Category < ActiveRecord::Base
  attr_accessible :title, :description, :parent_id, :category_image_attributes

  has_many :subcategories, class_name: 'Category', foreign_key: 'parent_id', dependent: :destroy
  belongs_to :parent_category, class_name: 'Category', foreign_key: 'parent_id'

我如何在ActiveRecord中完成此操作?

== UPDATE ==

所以我最终自己弄清楚了,但是我会留下这个问题,看看是否有更有效的方法来解决它:

def self.all_third_level_categories
  all_ids_of_categories_with_parents = Category.where("parent_id IS NOT NULL").map { |c| c.id }
  Category.find_all_by_parent_id(all_ids_of_categories_with_parents)
end

1 个答案:

答案 0 :(得分:0)

扩展@bcd的注释,你提供的实现需要n-1个查询来获取深度为n的对象,这很快就会变得很讨厌。

另一方面,在保存

的地方略有开销
def set_level
  self.level = parent_category.level + 1
end

可以解决问题。