【问题标题】:create date between scope in model在模型范围之间创建日期
【发布时间】:2014-08-05 01:12:17
【问题描述】:

我有一个具有“date_starting”和“date_ending”属性的模型。我想在我的模型中创建一个范围,指示模型是否在使用 Time.now 的日期开始和日期结束范围内。

类似

scope :activeAtDate, lambda{ |date = Date.today| where("? BETWEEN date_starting AND date_ending", date) }

我使用了这个不同的帖子,但作为一个新手,我很难做到这一点。

更新:

控制器

        @current = Guide.activeAtDate

谢谢,

【问题讨论】:

  • 我添加了我的控制器

标签: ruby-on-rails ruby postgresql time


【解决方案1】:

您的查询逻辑是相反的,您必须找到每个 date_* 字段的界限。
你可以这样做

scope :active_at_date, lambda {
  where("date_starting < :date and date_ending > :date", date: Date.today )
}

无需为您的 lambda 提供参数。因为参数总是一样的。

如果您需要更改日期,您可以将其重写为

scope :active_at_certain_date, lambda { |date|
  where("date_starting < :date and date_ending > :date", date: date )
}

【讨论】:

    猜你喜欢
    • 2021-09-09
    • 2013-08-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多