Najpierw upewnij się, że tabela mysql.time_zone_name jest wypełniona. Jeśli jest pusty, możesz postępować zgodnie z instrukcjami na tej stronie, aby go wypełnić:
http://dev.mysql.com/doc /refman/5.1/en/time-zone-support.html
Zwykle jest to tak proste, jak uruchomienie w powłoce takiego polecenia:
mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root mysql
Po wypełnieniu tej tabeli możesz użyć funkcji CONVERT_TZ(), aby zaktualizować istniejące wartości w bazie danych:
http://dev .mysql.com/doc/refman/5.1/en/data-i-godzina-funkcje.html#function_convert-tz
Oto dwa przykłady pokazujące, jak konwertuje daty i godziny z CET na UTC zimą i latem:
mysql> SELECT CONVERT_TZ('2010-01-22 12:00:00','CET','UTC');
+-----------------------------------------------+
| CONVERT_TZ('2010-01-22 12:00:00','CET','UTC') |
+-----------------------------------------------+
| 2010-01-22 11:00:00 |
+-----------------------------------------------+
1 row in set (0.00 sec)
mysql> SELECT CONVERT_TZ('2010-07-22 12:00:00','CET','UTC');
+-----------------------------------------------+
| CONVERT_TZ('2010-07-22 12:00:00','CET','UTC') |
+-----------------------------------------------+
| 2010-07-22 10:00:00 |
+-----------------------------------------------+
1 row in set (0.00 sec)