为什么数据库时间值与ruby时间对象中创建的值不同?

时间:2013-04-19 22:06:30

标签: sqlite activerecord ruby-on-rails-3.2

我的seeds.rb文件中包含以下代码:

# create a 7 day wall
for day in 1..7
    # create the days
    d = Day.create(day: day)
    # for each day create the time slots. Use 15 minute timeslots for now
    start_time = Time.new.beginning_of_day
    puts start_time
    end_time = start_time.end_of_day
    puts end_time
    begin
            d.time_slots << TimeSlot.create(time: start_time)
            start_time += 15.minutes
            puts start_time
    end while start_time <= end_time
            puts "Start time after exit: #{start_time}"

    campaign.days << d
end

按照人们的预期创建正确的输出

2013-04-19 00:00:00 -0700
2013-04-19 23:59:59 -0700
2013-04-19 00:15:00 -0700
2013-04-19 00:30:00 -0700
2013-04-19 00:45:00 -0700
2013-04-19 01:00:00 -0700
2013-04-19 01:15:00 -0700
2013-04-19 01:30:00 -0700
2013-04-19 01:45:00 -0700
2013-04-19 02:00:00 -0700
2013-04-19 02:15:00 -0700
2013-04-19 02:30:00 -0700
2013-04-19 02:45:00 -0700
2013-04-19 03:00:00 -0700
2013-04-19 03:15:00 -0700
2013-04-19 03:30:00 -0700
....

当我使用sqlite浏览器查看我的数据库时,我也看到了这一点。使用我的rails控制台检查数据库时,我看到:

1.9.3p194 :001 > TimeSlot.find(1)
  TimeSlot Load (17.3ms)  SELECT "time_slots".* FROM "time_slots" WHERE "time_slots"."id" = ? LIMIT 1  [["id", 1]]
 => #<TimeSlot id: 1, time: "2000-01-01 07:00:00", created_at: "2013-04-19 21:56:58", updated_at: "2013-04-19 21:56:58", campaign_id: nil, day_id: 1>

为什么数据库中的记录显示错误的日期?时间戳是正确的,但时间字段是错误的。我不明白。

1 个答案:

答案 0 :(得分:0)

这个问题有两件事情发生了:

  1. 在rails中使用timedatetime类型有一些细微差别。请参阅Time fields in Rails coming back blank
  2. 时区是个问题。 db以UTC / GMT格式存储时间。调用Time.new时,它使用系统的当前时区。
  3. 增加时间对象的代码是正确的。我只是在显示时间时考虑时区。