• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    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批量将时间戳转为通用日期格式示例代码
    上一篇:MongoDB分片在部署与维护管理中常见的事项总结大全
    下一篇:MongoDB学习以及集群搭建的实践全纪录
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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