gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 01:37:24 25 4
gpt4 key购买 nike

我正在使用 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

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

第二次尝试

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

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

问题是我应该怎么做才能返回没有 10:00:00 的日期。还是有更好的方法?

最佳答案

您的方法存在一些问题。

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

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

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

在这种情况下,MST/MDT 在 MySQL 时区表中称为“MST7MDT”,EET/EEST 称为“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)

关于php - 使用 MySQL 将 CURDATE() 转换为我的本地日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37228942/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com