我有一个通过云服务提供商托管的MySQL数据库。时区与我的本地时区不同。我正在尝试正确设置时区..
这是我在想要获得与MySQL数据库的新连接时使用的PHP代码:
static function get() {
if (self::$instance!=null) return self::$instance;
try {
self::$instance = new Database("mysql:host=".self::$host.";dbname=".self::$dbname, self::$user, self::$pass);
self::$instance->exec("SET NAMES 'utf8';"); //Use utf8 encoding for special characters
self::$instance->exec("SET time_zone = '+01:00';"); // set to local timezone
return self::$instance;
}
catch(PDOException $e) {
print $e->getMessage();
return null;
}
}
每当我在表中插入新条目时,时间戳仍设置为云服务提供商的时区。谁能帮忙看看我做错了什么?
您确定为字段使用 TIMESTAMP 类型吗?MySQL的时间戳类型将数据存储为UTC,并在您读取数据时转换为当前会话时区。DATETIME 类型不执行此操作,它没有时区信息,因此无法转换。请参阅此处与此主题相关的文档。
例如:
mysql> CREATE TABLE test (some_date DATETIME, created timestamp);
Query OK, 0 rows affected (0.09 sec)
mysql> INSERT INTO test (some_date) VALUES (NOW());
Query OK, 1 row affected (0.05 sec)
mysql> SELECT * FROM test;
+---------------------+---------------------+
| some_date | created |
+---------------------+---------------------+
| 2013-11-05 13:14:56 | 2013-11-05 13:14:56 |
+---------------------+---------------------+
1 row in set (0.00 sec)
mysql> SET time_zone = '+4:00';
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM test;
+---------------------+---------------------+
| some_date | created |
+---------------------+---------------------+
| 2013-11-05 13:14:56 | 2013-11-05 17:14:56 |
+---------------------+---------------------+
在上面的示例中,只有 TIMESTAMP 列受会话time_zone更改的影响。如果需要将 DATETIME 列转换为其他时区,则应在读取数据时使用 CONVERT_TZ 函数 - 指定数据所在的时区以及希望将其转换为的时区。