ruby-on-rails - 检查日期是否在日期范围内

标签 ruby-on-rails ruby date activerecord 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

关于ruby-on-rails - 检查日期是否在日期范围内,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25913604/

相关文章:

ruby-on-rails - 为什么回形针后期处理不起作用?

ruby-on-rails - Rails 4 - 想让 Rails 将我的本地时区用于 created_at 和 updated_at

ruby-on-rails - 在 Rails 中使用 Postgres 枚举类型时,在迁移中指定 CREATE TYPE xyz_setting AS ENUM 会破坏您的 db/schema.rb 文件

ruby - 如何使用 ruby​​-git 递归克隆远程存储库?

C# - 两个日期之间的差异?

MYSQL 在时间戳上选择日期

ruby-on-rails - 受控用户组的 Heroku SSL 证书

ruby - 如何在 github 操作中捆绑安装私有(private) gem

ruby-on-rails - Redmine 发送邮件两次

sql - 在我的查询中使用 datepart 添加一年并减去一天