【问题标题】:Is better way to write this date range scope?编写此日期范围范围的更好方法是什么?
【发布时间】:2013-09-18 00:25:50
【问题描述】:

我有选择班次的余地:

scope :by_date, lambda { |date|
  where "end_date BETWEEN ? AND ? OR start_date BETWEEN ? AND ?", date.beginning_of_day, date.end_of_day, date.beginning_of_day, date.end_of_day
}

有更清洁的方法吗?

【问题讨论】:

    标签: mysql ruby-on-rails ruby scope


    【解决方案1】:
    scope :by_date, lambda { |date| 
      where("DATE(start_date) = :date OR DATE(end_date) = :date", date: date.to_date) 
    }
    

    【讨论】:

    • 你应该把它改成where(["DATE(start_date) = :date OR DATE(end_date) = :date", date: date.to_date]) }
    【解决方案2】:

    这个怎么样:

    scope :by_date, lambda { |date|
      where("end_date BETWEEN :beginning AND :end OR start_date BETWEEN :beginning AND :end",
        beginning: date.beginning_of_day, end: date.end_of_day)
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-04-01
      • 2014-01-07
      • 1970-01-01
      • 2017-12-14
      • 1970-01-01
      • 2022-01-23
      相关资源
      最近更新 更多