Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Mysql:DB von Ortszeit in UTC konvertieren

Zuerst müssen Sie sicherstellen, dass die Tabelle mysql.time_zone_name gefüllt ist. Wenn es leer ist, können Sie den Anweisungen auf dieser Seite folgen, um es zu füllen:

http://dev.mysql.com/doc /refman/5.1/en/time-zone-support.html

Es ist normalerweise so einfach wie das Ausführen eines Befehls wie diesem in der Shell:

mysql_tzinfo_to_sql /usr/share/zoneinfo | mysql -u root mysql

Sobald diese Tabelle gefüllt ist, können Sie die Funktion CONVERT_TZ() verwenden, um die vorhandenen Werte in der DB zu aktualisieren:

http://dev .mysql.com/doc/refman/5.1/en/date-and-time-functions.html#function_convert-tz

Hier sind zwei Beispiele, die zeigen, wie Datums- und Uhrzeitangaben im Winter vs. Sommer von MEZ in UTC konvertiert werden:

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)