我正在使用 Godaddy 的 MySQL 数据库。由于他们的时区是 MST UTC -7,我需要修改我的代码。我在使用 NOW() 函数时想出了如何做到这一点。然而,我在将 CURDATE() 的结果转换为我的本地日期时挣扎。网站上的主题没有帮助。我没有权限更改 mysql 的时区,因为它是共享主机。关于 CURDATE() 的问题是,由于服务器和我所在的国家/地区之间存在 10 小时的差异,因此日期在某些时候会有所不同。
到目前为止我尝试过的
第一次尝试
SELECT convert_tz(CURDATE(),'-07:00','+03:00')
Run Code Online (Sandbox Code Playgroud)
此查询在 mysql 中返回以下输出。
convert_tz(CURDATE(),'-07:00','+03:00')
2016-05-14 10:00:00
Run Code Online (Sandbox Code Playgroud)
我还没有尝试,因为日期仍然相同,但这段代码可能完成了工作。但问题是关于日期之后的时间。CURDATE 应该只返回日期。我认为它返回等于 10 小时的两个时区之间的差异,但我认为当我比较 2 个日期时它会导致问题。
第二次尝试
SELECT convert_tz(CURDATE(),'MST','EEST');
Run Code Online (Sandbox Code Playgroud)
由于服务器的时区是 MST 而我的时区是 EEST,我以这种方式尝试但它返回 NULL。
问题是我应该怎么做才能在没有 10:00:00 的情况下返回日期。或者有什么更好的方法吗?