在 PHP 和 MySQL 中同步时区
您正在开发一个需要使用 PHP date() 函数在 MySQL 中存储日期的应用程序。有必要使用 NOW() 在 MySQL 中比较这些日期来计算时间差异。但是,PHP date() 函数使用 PHP 中定义的时区,而 NOW() 使用 MySQL 服务器中配置的时区。
为了解决此问题,您尝试了多种方法:
最终,MySQL 时区仍然存在
解决方案
同步 PHP 和 MySQL 中的时区,无需手动控制台命令或修改 php.ini:
PHP:
define('TIMEZONE', 'Europe/Paris');
date_default_timezone_set(TIMEZONE);
MySQL:
$now = new DateTime();
$mins = $now->getOffset() / 60;
$sgn = ($mins d', $hrs*$sgn, $mins);
// Assuming an existing DB connection named $db
$db->exec("SET time_zone='$offset';");
这种方法确保 PHP 和 MySQL 使用相同的时区,消除日期存储和比较方面的差异。此外,它消除了手动时区设置或修改全局配置文件的需要。
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3