开发者

Rails timezones VS MySQL timezones

开发者 https://www.devze.com 2023-04-10 11:35 出处:网络
In my Rails (3.0) application, I use timezones using the helper time_zone_select(). It generates timezone names like \"(GMT+01:00) Paris\"...

In my Rails (3.0) application, I use timezones using the helper time_zone_select(). It generates timezone names like "(GMT+01:00) Paris"...

But these names are different from those in MySQL, where the same timezone would be "Europe/Paris".

How can I convert Rails timezones to MySql ones ?

The tricky part is that for several reasons I have to use the default Rails helper, and in my models I have to use the MySQL timezones. So I can't use Ruby timezones in my models, and I can't use a list of MySQL timezones instead of the Rails helper... I really need a way to convert from the first to the latter.

Any idea?

Edit: I'm currently trying to use ActiveSupport::TimeZone[(ruby_timezone)].tzinfo.name, is there a开发者_Go百科 better way?


Okay, I finally found a way :

ActiveSupport::TimeZone[ruby_timezone].tzinfo.name

Romain suggested there may be some Rails timezones not supported by MySQL, so I tested the following in the console, and the answer is: they all work :)

ActiveSupport::TimeZone.all.each do |ruby_timezone|
  mysql_timezone = ActiveSupport::TimeZone[ruby_timezone.name].tzinfo.name
  puts ActiveRecord::Base.connection.execute("select convert_tz('2011-01-01 00:00:00', 'UTC', '#{mysql_timezone}')").first
  end
end

If a timezone was not supported by MySQL, it would have returned nil.

I don't know if there is a better way, but at least it works :)

0

精彩评论

暂无评论...
验证码 换一张
取 消