我有一个问题,我正在使用带有PHP的mysql,我在我的数据库中有时间戳列,这些列在当前时间戳的更新时自动设置。但是当我试图在表格中插入行时,行添加时间戳与当前时间不同(两小时之前)我有EST时区。
我已经检查了数据库的时区,它是系统,当我搜索它时,我读到它依赖于连接的机器,但是我的机器有EST时间,所以任何人都可以解释为什么我有这个?以及如何将我的数据库的当前时间戳设置为EST?
答案 0 :(得分:0)
我个人发现在PHP中设置时区更加可靠,然后在那里获取时间戳并将其传递给MySQL查询。
类似的东西:
date_default_timezone_set('America/New_York');
$curtimestamp = date('Y-m-d G:i:s', time());
然后在查询中使用$ curtimestamp的值。
答案 1 :(得分:0)
文档可能不清楚。
time_zone=SYSTEM
表示MySQL服务器时区源自运行MySQL服务器的主机,不客户端系统。
因此,如果MySQL服务器主机上的时区与客户端主机的时区不同,则说明您观察到的行为。
每个客户端(数据库会话)都有自己的time_zone
设置。建立连接后,设置将从"默认" MySQL服务器的时区。
此变量的设置确定如何解释DATETIME和TIMESTAMP值,何时将值从客户端发送到数据库,以及何时从数据库中提取现有值。
客户端可以发出SET time_zone
语句来更改数据库会话的time_zone,例如
SET time_zone=CST6CDT
(请注意,要使用时区的命名值,必须填充time_zone%
数据库中的mysql
表。)
设置"默认" time_zone将用于新的数据库连接,您可以设置" global" time_zone变量:
SET GLOBAL time_zone=
(此更改需要SUPER权限,它会影响到整个实例的所有新数据库连接。通常,此值在MySQL服务器配置文件中设置。)
对于TIMESTAMP
列,MySQL将这些列存储为UTC。返回给客户端的值取决于客户端time_zone
的设置。作为一个简单的演示:
mysql> CREATE TABLE mytest
-> ( id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY
-> , ts TIMESTAMP DEFAULT CURRENT_TIMESTAMP
-> );
Query OK, 0 rows affected (0.11 sec)
mysql> SHOW VARIABLES LIKE 'time_zone';
+---------------+--------+
| Variable_name | Value |
+---------------+--------+
| time_zone | +00:00 |
+---------------+--------+
1 row in set (0.00 sec)
mysql> INSERT INTO mytest (id) VALUES (NULL);
Query OK, 1 row affected (0.00 sec)
mysql> SELECT * FROM mytest;
+----+---------------------+
| id | ts |
+----+---------------------+
| 1 | 2015-01-09 15:41:25 |
+----+---------------------+
1 row in set (0.00 sec)
mysql> SET time_zone = 'CST6CDT';
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM mytest;
+----+---------------------+
| id | ts |
+----+---------------------+
| 1 | 2015-01-09 09:41:25 |
+----+---------------------+
1 row in set (0.00 sec)
mysql> INSERT INTO mytest (id) VALUES (NULL);
Query OK, 1 row affected (0.00 sec)
mysql> SELECT * FROM mytest;
+----+---------------------+
| id | ts |
+----+---------------------+
| 1 | 2015-01-09 09:41:25 |
| 2 | 2015-01-09 09:41:25 |
+----+---------------------+
2 rows in set (0.00 sec)
mysql> SET time_zone = 'EST5EDT';
Query OK, 0 rows affected (0.00 sec)
mysql> SELECT * FROM mytest;
+----+---------------------+
| id | ts |
+----+---------------------+
| 1 | 2015-01-09 10:41:25 |
| 2 | 2015-01-09 10:41:25 |
+----+---------------------+
2 rows in set (0.00 sec)