php获取时间和MongoDB保存时间不一致

最近遇到了问题,php获取的时间和在MongoDB中查看的时间差了8小时,原因是:

PHP 与 MongoDB 的默认时区设置不同

  • PHP 默认可能使用服务器的本地时区,或者是在 PHP 配置文件(php.ini)中设置的时区。(服务器默认的是Asia/Shanghai)
  • MongoDB 默认将时间存储为 UTC 时间。这意味着如果你在不进行任何时区转换的情况下将时间从 PHP 保存到 MongoDB,时间将自动转换为 UTC 时间。

最后导致的Navicat中查看的时候,MongoDB获取的时间是UTC格式的。不过后面使用php代码读取的时候,自动转化为Asia/Shanghai,所以问题不大。不用做特殊的处理。

以下是一个示例代码,演示如何将 UTC 时间转换为 Asia/Shanghai 时区的时间:

php 复制代码
<?php
// 假设 $utcTime 是一个包含 UTC 时间的字符串,例如 "2023-12-01 09:04:21"
$utcTime = "2023-12-01 09:04:21";

// 创建一个代表 UTC 时间的 DateTime 对象
$utcDateTime = new DateTime($utcTime, new DateTimeZone('UTC'));

// 设置时区为 'Asia/Shanghai'
$shanghaiTimeZone = new DateTimeZone('Asia/Shanghai');
$utcDateTime->setTimezone($shanghaiTimeZone);

// 格式化并打印 'Asia/Shanghai' 时间
$shanghaiTime = $utcDateTime->format("Y-m-d H:i:s");
echo $shanghaiTime;
?>

打印出来的是:2023-12-01 17:04:21

相关推荐
LLON erva9 分钟前
Redis-配置文件
数据库·redis·oracle
童话ing9 分钟前
【Redis】026 互联网大厂 Redis 面试高频题
数据库·redis·面试
钰衡大师11 分钟前
Activiti 7 工作流技术文档
java·数据库·spring boot
Treh UNFO15 分钟前
nginx的重定向
大数据·数据库·nginx
jvvz afqh23 分钟前
mysql用户名怎么看
数据库·mysql
eDEs OLDE26 分钟前
CC++链接数据库(MySQL)超级详细指南
c语言·数据库·c++
EXnf1SbYK27 分钟前
Redis分布式锁进阶第八篇:锁超时乱序深度踩坑 + 看门狗失效真实溯源 + 业务长耗时标准化兜底方案
数据库·redis·分布式
EXnf1SbYK36 分钟前
Redis分布式锁进阶第十一篇
数据库·redis·分布式
xiaohe0742 分钟前
C#数据库操作系列---SqlSugar完结篇
网络·数据库·c#
冬奇Lab1 小时前
RAG 系列(六):向量数据库——存储与检索的基础设施
数据库·人工智能·llm