3

有没有办法将一个模型范围用作另一个模型范围的一部分?

例子

class DocumentVersion < ActiveRecord::Base
  belongs_to :document
  scope :are_latest, lambda{ where(latest: true)}
end

class Document < ActiveRecord::Base
  has_many :document_versions
  scope :are_latest, lambda { ...something... } # I want something that will get documents that have documnet_versions that are_latest

  # I know I can do this 
  scope :are_latest,   lambda{ joins(:document_versions).where('document_versions.latest = true') }  # this works well

  # but I would like to keep that condition its own model
  scope :are_latest, lambda { joins(:document_versions).are_latest } # this wont obviously work, but something like that 

end
4

1 回答 1

3

是的,您可以使用合并将范围组合在一起。

class Document < ActiveRecord::Base
  has_many :document_versions

  scope :are_latest, lambda { joins(:document_versions).merge(DocumentVersion.are_latest) }
end
于 2012-11-06T13:07:58.707 回答