Mysql
 sql >> база данни >  >> RDS >> Mysql

Изясняване на часовата зона на PHP/MySQL

Мисля, че това търсиш;

$dt_obj = new DateTime($row['date']); 
$dt_obj->setTimezone(new DateTimeZone('America/Los_Angeles')); 
echo $dt_obj->format('Y-m-d H:i:s');

Използвайте Списъка с поддържани часови зони .

Актуализация на редактиран въпрос:За да сте сигурни, че PHP вижда времето от базата данни като UTC, направете нещо подобно:

$row['time'] = '2009-11-08 09:06:40';

$dt_obj = new DateTime($row['time'], new DateTimeZone('UTC')); 
echo 'UTC: ' . $dt_obj->format('Y-m-d H:i:s') . '<br />';  // UTC: 2009-11-08 09:06:40
$dt_obj->setTimezone(new DateTimeZone('America/Los_Angeles')); 
echo 'Los Angeles: ' . $dt_obj->format('Y-m-d H:i:s');  // Los Angeles: 2009-11-08 01:06:40


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySql - HAVING срещу WHERE

  2. Изчислете текущата сума в MySQL

  3. PDO обвързващи стойности за MySQL IN израз

  4. MySQL InnoDB ограничение не работи

  5. Обединяване на две таблици с различен брой колони