渴望加载嵌套关联和范围

Mar*_*rov 5 ruby-on-rails

我是初学者,很难解释我的问题:

我的模特:

class Skill  
  has_many :categories
  has_many :positions, :through => :categories
end

class Category
  belongs_to :skill
  has_many :positions  
end

class Position
  belongs_to :category
  has_one :skill, :through => :category    
end
Run Code Online (Sandbox Code Playgroud)

我可以成功地加载所有内容,如下所示:

@skills = Skill.includes(:positions)
Run Code Online (Sandbox Code Playgroud)

但有时我想在职位上应用范围:

class Position
...
  scope :active, where(:hidden => false)
end
Run Code Online (Sandbox Code Playgroud)

我希望我能做到:

@skills = Skill.includes(:positions.active)
Run Code Online (Sandbox Code Playgroud)

相反,我在视图中应用范围,但是急切加载不再起作用:

<%= skill.positions.acitve ... %>
Run Code Online (Sandbox Code Playgroud)

是否可以同时拥有热切的装载和范围?

Mic*_*ant 7

您可以使用其他关联:

class Skill  
  has_many :categories
  has_many :positions, :through => :categories
  has_many :active_positions, :through => :categories
end

class Category
  belongs_to :skill
  has_many :positions  
  has_many :active_positions, :class_name => "Position", :conditions => {:hidden => false}
end

class Position
  belongs_to :category
  has_one :skill, :through => :category    
end
Run Code Online (Sandbox Code Playgroud)

然后

@skills = Skill.includes(:active_positions)
Run Code Online (Sandbox Code Playgroud)

但是你会得到两个联想.如果你曾经使用过skill.positions,那么所有技能的位置都将从数据库中加载.你应该只使用skill.active_positions.