ruby-on-rails – 查找与Rails中的范围重叠的记录

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 查找与Rails中的范围重叠的记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以,我有一个事件模型有一个starts_at和ends_at列,我想查找发生在一系列日期的事件.

我想出了这个named_scope(范围通常是一个月):

named_scope :in_range,lambda { |range|
  {:conditions => [
    'starts_at BETWEEN ? AND ? OR ends_at BETWEEN ? AND ?',range.first,range.last,range.last]} }

哪些工作如预期.

但是,如果一个事件从前一个月开始,并在该范围之后的月份结束,则不会显示.有没有办法以正确的方式找到这些事件?

解决方法

有四种情况:
Start    End
1.      |-----|
2.  |------|
3.  |-------------|
4.         |------|

你的named_scope只会得到1,2和4的情况.所以你只需要添加

named_scope :in_range,lambda { |range|
  {:conditions => [
     '(starts_at BETWEEN ? AND ? OR ends_at BETWEEN ? AND ?) OR (starts_at <= ? AND ends_at >= ?)',range.last
   ]}
}

猜你在找的Ruby相关文章