sql >> Databáze >  >> RDS >> Mysql

Mysql:Převod DB z místního času na UTC

Nejprve se musíte ujistit, že je vyplněna tabulka mysql.time_zone_name. Pokud je prázdný, můžete jej vyplnit podle pokynů na této stránce:

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

Obvykle je to tak jednoduché, jako spuštění příkazu jako je tento v shellu:

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

Jakmile je tato tabulka naplněna, můžete použít funkci CONVERT_TZ() k aktualizaci stávajících hodnot v DB:

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

Zde jsou dva příklady, které ukazují, jak převádí datum a čas z CET na UTC v zimě vs. léto:

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. Vytváří cizí klíč automaticky index?

  2. Jak extrahovat pouze hodnotu data z pole data v Oracle?

  3. Jak mohu filtrovat dotaz podle hodinové části pole DateTime v MySQL?

  4. Upozornění MariaDB:'[email protected]' má obojí... Heslo bude ignorováno