我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MongoDB存储时间时差问题的解决方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MongoDB存储时间时差问题的解决方法

前言

MongoDB存储时间类型数据时,都是先转换为UTC时间,然后存储到数据库中,当我们取出存储的时间时,就会出现时差的问题。

比如我们用的北京时间,读取到的数值就会看到比当前时间少了8个小时,难道说我们在每次读取的时候都要单独处理一下时间吗,这就比较麻烦。其实,我们可以在存储的时候进行相应的处理,只需使用getTimezoneOffset()toISOString()函数。

需要了解的概念:

格林威治时间

格林威治子午线上的地方时,或零时区(中时区)的区时叫做格林威治时间,也叫世界时。(更多详细的概念不说了,这里我们不需要。) 比如我们中国是东八区,北京时间是(GMT+08:00)

获得本地与格林威治时间的时差:new Date().getTimezoneOffset(),单位为分钟。

已知格林威治时间,换算本地正确时间

本地时间 = 格林威治时间 - 时差

已知本地时间,换算对应格林威治时间:

格林威治时间 = 本地时间 + 时差

已知本地时间,换算其他时区的时间

因为时区间的差异是以小时为单位的。所以算出0时区的时间后,再减去或加上相应的小时即可(东N区便+N小时,西N区便-N小时)。 为了方便计算,东N区记做正数,西N区记做负数,即:

目标时区时间 = 本地时间 + 时差 + 时区间隔

getTimezoneOffset函数:返回此地区的时差(当地时间与GMT格林威治标准时间的地区时差),单位为分钟。


<script>
 // 我们是东八区
 var d = new Date();
 var tz = d.getTimezoneOffset();
 console.log(tz); // -480
</script>

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MongoDB存储时间时差问题的解决方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

解决MySQL存储时间出现不一致的问题

用Java在获取了系统时间后,存入MySQL数据库时,当时间的类型为datetime或Timestamp时发现数据库的存储与本地时间不一致。 很大原因是,MySQL设置的时区与你本地时区不一致造成的,解决办法可以修改MySQL的时区配置,这
2022-05-25

如何解决MySQL存储时间出现不一致的问题

小编给大家分享一下如何解决MySQL存储时间出现不一致的问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!用Java在获取了系统时间后,存入MySQL数据库时,当时间的类型为datetime或Timestamp时发现数据库
2023-06-14

解决MySQL时区日期时差8个小时的问题

目录场景:解决:mysql查出时间相差14小时问题重现问题排查场景:我们在mysql客户端查询 now() 系统当前日期时间,会发现得到的结果比系统实际日期时间慢8个小时左右,这是由于不同的时区导致的解决:1、在 mysql 的服务端
2023-01-04

MYSQL时区导致时间差了14或13小时的解决方法

目录CST 时区排错过程解决方案mysql时区有问题(相差13或14小时)p>我一般使用MYSQL定义字段类型时,一般使用TIMESTAMP时间戳来定义创建时间与更新时间,并将其定义为默认值为CURRENT_TIME,但是由于场景特殊,现在
2023-01-04

nginx设置超时时间的问题及解决方案

nginx超时设置常见问题包括启动超时、读写超时、keepalive超时和发送超时。优化超时设置的最佳实践包括识别关键请求、使用合理默认值、根据负载调整超时、使用keepalive连接和监视超时错误。具体示例包括增加启动超时、调整读写超时、优化keepalive超时和减少发送超时。
nginx设置超时时间的问题及解决方案
2024-04-02

php方法执行时间过长的问题怎么解决

这篇文章主要讲解了“php方法执行时间过长的问题怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php方法执行时间过长的问题怎么解决”吧!php方法执行时间过长的解决办法:1、进行Ng
2023-06-20

解决MongoDB技术开发中遇到的数据存储问题的方法研究

解决MongoDB技术开发中遇到的数据存储问题的方法研究摘要:随着大数据时代的到来,数据存储与处理成为了技术开发中的重要环节。MongoDB作为一种非关系型数据库,具有强大的数据存储和处理能力,但在实际开发中也存在一些问题。本文将研究并提出
2023-10-22

BAT怎么获取时间有空格问题的解决方法

小编给大家分享一下BAT怎么获取时间有空格问题的解决方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!最近在项目上需要把文件定时备份,用BAT文件来自动生成文件夹名,精确到秒:bat脚本时间设定如下:pushd E:\Te
2023-06-08

编程热搜

目录