我的 Rails 3 应用程序中有以下代码:
scope :active, lambda {
where("starts_at <= ? AND ends_at >= ?", Time.now.utc, Time.now.utc)
}
scope :since, lambda { |hide_time|
where("updated_at > ? OR starts_at > ?", hide_time.utc, hide_time.utc) if hide_time
}
def self.display(hide_time)
active.since(hide_time)
end
但是,无论年份是否与当前年份匹配,我都想返回结果。只要日期和月份匹配就可以了。这可能吗?
和starts_at
列ends_at
已datetime
格式化。因此,即使我没有在表格中设置一年,它们也会自动包含一年:
<%= f.datetime_select :starts_at, :order => [:day, :month], :discard_year => true %>
任何指针将不胜感激。