sql >> Databasteknik >  >> RDS >> Mysql

Mysql:Konvertera DB från lokal tid till UTC

Först måste du se till att tabellen mysql.time_zone_name är ifylld. Om den är tom kan du följa instruktionerna på den här sidan för att fylla i den:

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

Det är vanligtvis så enkelt som att köra ett kommando som detta i skalet:

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

När den tabellen är ifylld kan du använda CONVERT_TZ()-funktionen för att uppdatera de befintliga värdena i DB:

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

Här är två exempel för att visa hur den konverterar datum från CET till UTC på vintern kontra sommaren:

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)


  1. Hur man hämtar uppladdade filer med php

  2. Utländska nyckelbegränsningar när data dumpas

  3. java.net.SocketException:Trasigt rör

  4. Hur uppdaterar jag automatiskt en tidsstämpel i PostgreSQL