21

在我的 MySQL 数据库中,updated_at 字段存储为 UTC。上周在美国东部时间晚上 7 点输入了一条记录,它的 updated_at 值为“2012-08-01 23:00:00”。我正在尝试将 Web 客户端的本地时间转换为可以与数据库中的 updated_at 字段进行比较的 UTC。

例如,我想将 '08/01/2012 07:00 pm' 转换为 '2012-08-01 23:00:00' (考虑到我在 EDT)但我错过了时区转换方面。'7:00 pm' 是当地时间,可以来自任何时区。我当前的代码:

ruby-1.9.2-head :015 > from_date = DateTime.strptime('08/01/2012 07:00 pm', '%m/%d/%Y %H:%M %p')
=> Wed, 01 Aug 2012 19:00:00 +0000 
ruby-1.9.2-head :016 > from_date = Time.zone.parse(from_date.to_s).utc
=> 2012-08-01 19:00:00 UTC

有什么想法吗?

编辑:另外,我可以在我的 strptime 调用中使用“%Z”,但这是假设我在值中有时区,而我目前没有。我想我可以使用 Javascript 将其与日期/时间值一起发送。

4

2 回答 2

40

本地到 UTC

created_at.utc

UTC到本地

created_at.localtime

于 2012-11-01T04:47:33.933 回答
1

首先,我会检查您的时区设置。

在您的 environment.rb (Rails 2) 或 application.rb (Rails 3) 文件中,您可以设置默认时区:config.time_zone = 'Eastern Daylight Time (EDT)'

其次,我会查看这篇文章以获取满足您需求的信息、指导和提示:http:
//databasically.com/2010/10/22/what-time-is-it-or-handling-timezones-in-rails/

于 2012-08-06T18:06:33.150 回答