Mysql
 sql >> Base de données >  >> RDS >> Mysql

Mysql :convertir la base de données de l'heure locale en UTC

Vous devez d'abord vous assurer que la table mysql.time_zone_name est remplie. S'il est vide, vous pouvez suivre les instructions de cette page pour le remplir :

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

C'est généralement aussi simple que d'exécuter une commande comme celle-ci dans le shell :

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

Une fois cette table remplie, vous pouvez utiliser la fonction CONVERT_TZ() pour mettre à jour les valeurs existantes dans la base de données :

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

Voici deux exemples pour montrer comment il convertit les dates et heures de CET en UTC en hiver par rapport à l'été :

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)