欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-07 23:19:55
前言 mongodb存储时间类型数据时,都是先转换为utc时间,然后存储到数据库中,当我们取出存储的时间时,就会出现时差的问题。 比如我们用的北京时间,读取到的数值就会...

前言

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()这个函数就可以了,无论你处在哪个时区结果显示都和当地时间一样。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。