36

假设我有一个标准的Post.first.created_at日期时间。我可以通过执行以下操作直接将其与格式中的日期时间进行比较2009-06-03 16:57:45.608000 -04:00

Post.first.created_at > Time.parse("2009-06-03 16:57:45.608000 -04:00")

编辑:两个字段都是datetimes而不是 dates

4

2 回答 2

51

是的,您可以使用比较运算符来比较日期,例如:

irb(main):018:0> yesterday = Date.new(2009,6,13)
=> #<Date: 4909991/2,0,2299161>
irb(main):019:0> Date.today > yesterday
=> true

但是您是否尝试将日期与日期时间进行比较?

如果是这种情况,您需要将日期时间转换为日期,然后进行比较。

我希望这有帮助。

于 2009-06-14T09:02:39.227 回答
10

是的,您可以直接将created_atActiveRecord 日期/时间字段的值与常规DateTime对象进行比较(例如您可以通过解析字符串获得的对象)。

在一个项目中,我有一个具有 created_at 日期时间对象的值对象:

imac:trunk luca$ script/console
Loading development environment (Rails 2.3.2)
>> Value.first.created_at
=> Fri, 12 Jun 2009 08:00:45 CEST 02:00
>> Time.parse("2009-06-03 16:57:45.608000 -04:00")
=> Wed Jun 03 22:57:45 0200 2009
>> Value.first.created_at > Time.parse("2009-06-03 16:57:45.608000 -04:00")
=> true

created_at 字段定义为:

  create_table "values", :force => true do |t|
    [...]
    t.datetime "created_at"
  end

注意如果您的字段是日期而不是日期时间,那么您需要将其转换为时间:

Post.first.created_at.to_time > Time.parse("2009-06-03 16:57:45.608000 -04:00")

或解析日期:

Post.first.created_at > Date.parse("2009-06-03 16:57:45.608000 -04:00")

否则你会得到:

ArgumentError: comparison of Date with Time failed
于 2009-06-14T09:43:23.560 回答