MongoDB存储时间时差问题的解决方法
2018-09-11 09:49
2031 查看
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()这个函数就可以了,无论你处在哪个时区结果显示都和当地时间一样。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- mysql-connector-java-6日期存储时差的问题解决方法
- vb6.format() 时间格式时出问题!解决方法
- 真正有效的解决VMware时钟/时间过快或过慢问题或者运行很慢的方法
- windwos下IIS日志时间问题的解决方法
- php date时间本地化问题 或是date函数时差问题的解决
- 存储过程参数的时间默认值解决方法
- Lucene搜索结果排序问题(按时间倒序排的替代解决方法)
- 真正有效的解决VMware时钟/时间过快或过慢问题的方法
- php中时差问题的解决方法
- 服务器asp.net权限设置问题及解决方法时间:
- VM 虚拟机linux 时间总是延迟问题解决方法
- 本地存储在IE下面的编码问题及解决方法
- oracle+jsp中blob类型存储大文本问题解决方法
- “超时时间已到。超时时间已到,但是尚未从池中获取连接。出现这种情况可能是因为所有池连接均在使用,并且达到了最大池大小。”问题的解决方法
- 共享一文件夹提示"服务器存储空间不足,无法处理此命令"的问题解决方法
- windwos下IIS日志时间问题的解决方法
- 在从池中获取连接之前超时时间已过,所有池连接都已被使用并已达到最大池大小的问题解决方法
- "服务器存储空间不足,无法处理此命令"问题解决方法
- 双系统时间同步问题的解决方法
- VMWARE内系统时间出现问题的解决方法一则