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

  • A+
所属分类: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>

toISOString()函数:使用ISO尺度将 Date 工具转换为字符串。

该尺度称为 ISO-8601 ,格局为: YYYY-MM-DDTHH:mm:ss.sssZ。

语法

Date.toISOString()

返回值

类型 描写

String
ISO 尺度格局的光阴与日期

封装光阴转换函数

localDate(v) {
 const d = new Date(v || Date.now());
 d.setMinutes(d.getMinutes() - d.getTimezoneOffset());
 return d.toISOString();
},

我们在存储光阴的时刻挪用localDate()这个函数就可以了,无论你处在哪个时区成果显示都和本地光阴一样。

总结

以上便是这篇文章的全体内容了,愿望本文的内容对年夜家的进修或者事情具有必定的参考进修代价,假如有疑问年夜家可以留言交流,谢谢年夜家对剧本之家的支撑。

您可能感兴致的文章:

深刻相识MongoDB是若何存储数据的MongoDB系列教程(八):GridFS存储详解PHP操作MongoDB GridFS 存储文件的详解PHP MongoDB GridFS 存储文件的办法详解Spring Boot集成Shiro并应用MongoDB做Session存储的办法详解Nodejs使用Mongodb存储与提供后端CRD服务详解python将MongoDB里的ObjectId转换为光阴戳的办法python依据光阴天生mongodb的ObjectId的办法穷究从MongoDB的ObjectId中获取光阴信息MongoDB批量将光阴戳转为通用日期格局示例代码

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: