hol*_*den 3 ruby arrays ruby-on-rails range days
我有一个名为named_scope的Rails,它使用一个条件从表中拉出一周中的特定日期,如下所示:
:conditions => [ 'EXTRACT(DOW FROM bookdate) IN (?)', (1..6).to_a ]
Run Code Online (Sandbox Code Playgroud)
1.6日期范围将是一个变量,具体取决于用户想要的日期,
哪个产生这个SQL
(EXTRACT(DOW FROM bookdate) IN (1,2,3,4,5,6)
Run Code Online (Sandbox Code Playgroud)
我的问题是,一周的日子不是一个简单的范围...即1..6工作正常(周一...周六),但说6..2将无法正常工作(周六 - 周二)...无论是作为红宝石范围还是需要6,7,1,2而不是6,5,4,3,2(假设6..2在红宝石中工作,它没有).
如何创建一个星期几的自定义范围,以适应这样的日期范围?
有任何想法吗?
谢谢,
如果你想要一个函数来生成包含的值范围,:conditions那么它将适用于像Sat-Tues和Mon-Sat这样的范围如何:
def day_range(from, to)
if from <= to
(from..to).to_a
else
(from..7).to_a + (1..to).to_a
end
end
Run Code Online (Sandbox Code Playgroud)
例如
irb(main):032:0> day_range(1, 6)
=> [1, 2, 3, 4, 5, 6]
irb(main):033:0> day_range(6, 2)
=> [6, 7, 1, 2]
Run Code Online (Sandbox Code Playgroud)
然后,如果需要,只是将日期名称映射到日期数字的情况.