有没有办法将一个模型范围用作另一个模型范围的一部分?
实施例
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
答案 0 :(得分:3)
是的,您可以使用merge将范围组合在一起。
class Document < ActiveRecord::Base
has_many :document_versions
scope :are_latest, lambda { joins(:document_versions).merge(DocumentVersion.are_latest) }
end