在我的Rails 3.2.8应用程序中,我有一些命名范围,我想在某些情况下链接在一起。
因此,例如,我有这两个范围:
scope :by_status, lambda { |status| if status == "All" then WorkRequest.all else WorkRequest.find_all_by_status(status) end }
scope :in_date_range, lambda { |start_date, end_date| includes([:person, :pier_module]).where("(status_date >= ?) AND (status_date <= ?)", start_date, end_date) }
我单独使用它们,但我也希望能够像这样一起调用它们:
WorkRequest.by_status("Accepted").in_date_range("2012-01-01", "2012-10-02")
当我尝试它时,它抱怨in_date_range不是Array的方法。
但我有另一个范围,
scope :active, includes([:person, :pier_module]).where("status = 'New Request'")
如果我这样做
WorkRequest.active.in_date_range("2012-01-01", "2012-10-02")
它有效!显然,活动范围返回一个Relation,而lambda范围返回Arrays,因此无法链接。
我很想知道为什么更简单的范围和lambda范围之间的区别,参数如何影响它,以及是否有任何我可以做的事情,而不是编写组合范围,我已经完成了。
scope :by_status_in_date_range, lambda { |status, start_date, end_date| includes([:person, :pier_module]).where("(status = ?) AND (status_date >= ?) AND (status_date <= ?)", status, start_date, end_date) }
工作,但不是很干(因为我也需要个别范围)或Rails-ish。在这里和其他地方搜索我已经看过类似的问题,但似乎没有一个适用于这种情况,我试图用参数链接两个lambda。
答案 0 :(得分:5)
这是因为你的范围
scope :by_status, lambda { |status| if status == "All" then WorkRequest.all else WorkRequest.find_all_by_status(status) end }
metods all
和find_all_by_status
返回Array
而不是ActiveRecord::Relation
。您应该将其替换为where
,例如。
scope :by_status, lambda { |status| where(:status => status) unless status == "All" }