记录数组每个元素的布尔值 true - Rails 4

Records where boolean true for each element of array - Rails 4

使用 rails 4.

我有一个 Spot 模型,一周中的每一天都有 7 个布尔属性:monday:booleantuesday:booleanwednesday:boolean

用户应该能够 select 一个日期范围,并且只返回那些日子可用的景点。

目前在设置查找正确记录的 class 方法时遇到问题。

到目前为止,我正在根据用户输入的日期创建一个范围,returns 一周中的所有日子都在该范围内。

range_array = (start_date..end_date).to_a.map{ |date| date.strftime("%A").downcase }
=> ["wednesday", "thursday", "friday"]

这就是我卡住的地方。我试图找到与数组中的元素对应的布尔字段为真的所有点。所以在上面的例子中,我想形成这个查询 Spot.where(wednesday: true, thursday: true, friday: true)

这样的事情可行吗?有 better/different 方法吗?也许我做错了。感谢任何 help/suggestions。

更新(对于 Andrey)...Spot.first 示例实例:

=> #<Spot id: 18, address: "4640 east skyline", title: "iodjiojoidj", description: "<p>jijiojfojewoif</p>\r\n", 
created_at: "2016-03-30 04:54:07", 
updated_at: "2016-09-26 05:39:51", 
user_id: 13, timezone: nil, 
surge_pricing: nil, free: nil, monday: true, 
tuesday: true, wednesday: true, thursday: false, 
friday: false, saturday: false, sunday: false> 

使用您的 range_array,您应该能够按如下方式进行查询:

query = range_array.inject({}) do |h, e|
          h[e] = true
          h
        end

Spot.where(query)