使用MySQL将CURDATE()转换为我的本地日期

时间:2016-05-14 16:09:30

标签: php mysql date datetime timezone

我正在使用Godaddy的MySQL数据库。由于他们的时区是MST UTC -7,我需要修改我的代码。我在使用NOW()函数时想出了如何做到这一点。但是我在将CURDATE()的结果转换为我的本地日期时遇到了困难。网站上的主题没有帮助它。我没有权限更改mysql的时区,因为它是共享主机。关于CURDATE()的问题是,由于服务器和我的国家之间存在10个小时的差异,因此日期在某些时候会有所不同。

到目前为止我尝试了什么

首次尝试

SELECT convert_tz(CURDATE(),'-07:00','+03:00')

此查询在mysql中返回以下输出。

convert_tz(CURDATE(),'-07:00','+03:00')     
2016-05-14 10:00:00

我还没有尝试,因为仍然是相同的日期,但这段代码可能完成了工作。但问题是关于date.CURDATE之后的时间应该只返回日期。我认为它会返回两个时区之间的差异,相当于10个小时,但我认为当我比较2个日期时,它会引起问题。

第二次尝试

SELECT convert_tz(CURDATE(),'MST','EEST');

由于服务器的时区是MST而我的时区是EEST,我尝试了这种方式,但它返回NULL。

问题是我应该怎么办才能在没有10:00:00的情况下返回日期。还是有更好的方法吗?

2 个答案:

答案 0 :(得分:4)

您的方法存在一些问题。

首先,CURDATE()返回日期,而不是日期时间。

其次,在截断时间部分之前,您需要将当前日期和时间从服务器的时区转换为时区。这意味着在内部使用NOW(),而不是CURDATE()

第三,您需要为整年的转换双方使用正确时区的正确缩写。如果无法识别任何时区,CONVERT_TZ()将返回NULL

在这种情况下,MST / MDT称为“MST7MDT”,EET / EEST在MySQL时区表中称为“EET”。令人惊讶的是,Go Daddy没有将他们的服务器时钟设置为UTC - 这是服务器时钟的事实上的标准,但假设没有,“MST7MDT”可能是最正确的值。

mysql> SELECT DATE(CONVERT_TZ(NOW(),'MST7MDT','EET'));
+-----------------------------------------+
| DATE(CONVERT_TZ(NOW(),'MST7MDT','EET')) |
+-----------------------------------------+
| 2016-05-14                              |
+-----------------------------------------+
1 row in set (0.00 sec)

或者,您可以使用更直观的本地化名称作为时区。我相信这些价值也是正确的,可以正确适应夏季和时间变化:

mysql> SELECT DATE(CONVERT_TZ(NOW(),'America/Denver','Europe/Bucharest'));
+-------------------------------------------------------------+
| DATE(CONVERT_TZ(NOW(),'America/Denver','Europe/Bucharest')) |
+-------------------------------------------------------------+
| 2016-05-14                                                  |
+-------------------------------------------------------------+
1 row in set (0.00 sec)

答案 1 :(得分:0)

尝试使用CAST将日期转换为字符串,然后获取子字符串。

SELECT SUBSTRING_INDEX( CAST(CONVERT_TZ(CURDATE(),'-07:00','+03:00') AS char), ':', -1)

应该返回

2016-05-14 10:00