我正在尝试将表中的日期/时间与当前时间进行比较,以查看该项目是否已过期。我尝试了很多组合,但似乎无法正确调整时区。我在东部标准时间。
create_table "admin_messages", force: :cascade do |t|
t.text "message"
t.datetime "expires"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
end
基本思想是我可以添加消息和到期日期,并显示尚未过期的消息。
application.rb
config.active_record.default_timezone = 'Eastern Time (US & Canada)'
config.time_zone = 'Eastern Time (US & Canada)'
end
我已经尝试了许多方法可以使下面的if语句正常工作,但无济于事。
helper_method :show_admin_messages
def show_admin_messages
$admin_message = ''
@admin_messages = AdminMessage.all
@admin_messages.each do |message|
if message.expires >= Time.now.in_time_zone("Eastern Time (US & Canada)")
$admin_message = $admin_message + message.message + "<br>"
end
end
end
如果我在Time.now上尝试几个变体,我会得到:
Time.now 2016-01-19 09:23:08 -0500
Time.now.utc 2016-01-19 14:23:08 UTC
Time.now.localtime 2016-01-19 09:23:08 -0500
Time.now.in_time_zone("Eastern Time (US & Canada)") 2016-01-19 09:23:08 -0500
我的问题是试图找出 if 语句的语法。
你可以只使用:
if message.expires.past?
## it expired
else
## not yet
end
您几乎肯定不想设置config.active_record.default_timezone
。默认值为 UTC - 对于其他时区,您会遇到诸如 DST 之类的问题,使记录看起来以错误的顺序重新创建,等等。
对于绝大多数应用程序,时区仅在向用户显示输出或接收输入时才相关。诸如筛选过期是在过去还是现在之类的操作不依赖于此:
message.expires <= Time.now
会做到的。
事件最好是
@admin_messages = AdminMessage.where('expires > ?', Time.now)
这样您首先只从数据库中获取未过期的消息。