[英]Check if the date is in date range
我有一个这样创建的对象数组:
all_project_assignments = ProjectAssignment.where(active: true, hour_type_id: 1)
现在,我想使用此结果数组仅选择日期范围内的分配。 日期范围是:
date_range = @current_month.at_beginning_of_month..@current_month.at_end_of_month
而且all_project_assignments的每个成员都具有必须在范围内的entry_date字段。
我的选择是:
project_assignments = ProjectAssignment.where(active: true, hour_type_id: 1, entry_date: date_range)
但是我不想要另一个数据库查询。 那么,什么是最好的方法呢?
您可以将查询链接在一起:
all_project_assignments = ProjectAssignment.where(active: true, hour_type_id: 1)
date_range = @current_month.at_beginning_of_month..@current_month.at_end_of_month
project_assignments = all_project_assignments.where(entry_date: date_range)
但是,这将再次查询数据库。
如果您要过滤检索到的行,只需执行
project_assignments = all_project_assignments.select do |assignment|
assignment.entry_date.between?(@current_month.at_beginning_of_month, @current_month.at_end_of_month)
end
在范围条件下检查Rails指南 :
Client.where(created_at: (Time.now.midnight - 1.day)..Time.now.midnight)
这将产生以下SQL:
SELECT * FROM clients WHERE (clients.created_at BETWEEN '2008-12-21 00:00:00' AND '2008-12-22 00:00:00')
因此,在您的情况下:
all_project_assignments = ProjectAssignment.where(active: true, hour_type_id: 1, entry_date: @current_month.at_beginning_of_month..@current_month.at_end_of_month)
请注意,如果按当前月份(1..12)
进行比较,您将获得同一月份的结果,但来自去年。
如果范围不过是整个月,那么您可以尝试使用此查询吗?
project_assignments = all_project_assignments.select do |assignment|
assignment.entry_date.month == @current_month
end
如果@current_month是整数,则可能
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.