我在“application.rb中”和restartet的WEBrick Web服务器的“重偏移”(耙分贝降迁移耙分贝)设置保存日期时间到数据库::时区错误
config.time_zone = 'Berlin'
config.active_record.default_timezone = :local
。
如果我在数据库的检查条目,一切都很好,和“created_at”被正确地保存在我的Localtimezone:
sqlite> select created_at from docversions;
2011-08-22 23:27:51.138723
sqlite>
但在这种情况下,这种“本地时区”不工作:
(creat.html.erb)
<%= form_for :token, :url => {:action => "save_token"}, :docversion_id => params[:id] do |f| %>
<%= f.datetime_select :validuntil, :order => [:day, :month, :year, :hour, :minute], :default => 3.days.from_now, %>
<%= f.submit %>
(tokenadmin_controller.rb)
class TokenadminController < ApplicationController
def save_token
@token = Token.new
civildate = DateTime.civil(params[:token]["validuntil(1i)"].to_i,
params[:token]["validuntil(2i)"].to_i,
params[:token]["validuntil(3i)"].to_i,
params[:token]["validuntil(4i)"].to_i,
params[:token]["validuntil(5i)"].to_i)
@token.validuntil = civildate
if @token.save
flash[:notice] = "Token created."
redirect_to :controller => :tokenadmin, :action => :admin
else
flash[:error] = "Token could not be saved!"
redirect_to :controller => "index"
end
end
end
它似乎将被保存为UTC:
sqlite> select validuntil, created_at from tokens;
2011-08-22 01:44:00.000000|2011-08-22 23:44:20.640434
sqlite>
正如你所看到的,created_at正确保存的当地时间,但validuntil保存+ 2H(但我选择了时间相同create_at ;-))。我认为它的+ 2h因为在UTC + 1和DST UTC + 2的时区。目前在DST。
这是一个错误,还是我做错了什么?
感谢您的帮助。
更新后职位从 “BaronVonBraun”:
谢谢!它的工作现在。 Databasefield仍然是 “时间戳”:
t.timestamp :validuntil
控制器代码,至极是用于创建时间字段:
前:
civildate = DateTime.civil(params[:token]["validuntil(1i)"].to_i,
params[:token]["validuntil(2i)"].to_i,
params[:token]["validuntil(3i)"].to_i,
params[:token]["validuntil(4i)"].to_i,
params[:token]["validuntil(5i)"].to_i)
后:
civildate = Time.parse("#{params[:token]["validuntil(1i)"].to_s}-#{params[:token]["validuntil(2i)"].to_s}-#{params[:token]["validuntil(3i)"].to_s} #{params[:token]["validuntil(4i)"].to_s}:#{params[:token]["validuntil(5i)"].to_s}")