成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

您的位置:首頁技術文章
文章詳情頁

javascript - JS new Date() 保存到 mongodb 中會早8個小時,我們這里是東八區,mongodb 保存的是格林尼治時間

瀏覽:151日期:2024-03-27 18:26:22

問題描述

我用的 mongoose ,這是我定義的 Schema :

const report = mongoose.Schema({ datetime: Date, username: String, detail: mongoose.Schema.Types.Mixed})

這是我存入的數據:

let params = { username: ’testadmin’, detail: ’23123’, datetime: new Date(’December 17, 1995 03:24:00’)}

存進 mongodb 中后存的時間會早八個小時:javascript - JS new Date() 保存到 mongodb 中會早8個小時,我們這里是東八區,mongodb 保存的是格林尼治時間‘95年12月17日凌晨3點’變成了‘12月16日晚上7點,時區搞錯了,,,請問大家這種情況應該怎么辦?mongodb 或者 mongoose 有相應的處理方法嗎?

小弟這里先謝過!

問題解答

回答1:

原來mongodb中存的是UTC時間,全球統一,,,那就直接存,再存之前不做操作,讀取出來后把時間new Date(report.datetime).toLocaleString(),調用js自帶的Date().toLocaleString()就行了

回答2:

因為 mongoose 和 sequelize 開始的時候,沒有考慮時區,ORM 之后就搞錯時區了。解決方法去看看最新版本是否解決,如果還未解決可以試試把問題發給作者,然后只能自己在應用層預處理,寫入 +8 小時,讀出 -8 。

回答3:

getTimezoneOffset() 方法可返回格林威治時間和本地時間之間的時差,以分鐘為單位。

回答4:

存成unix時間戳吧,這樣就不會有啥問題了,取出來的時候 根據時區去處理轉換就可以了

回答5:

你在把那個iso時間new Date回來就好了,存的是iso標準時間,new Date的時候回自動轉成本地時區

回答6:

正如樓上有同學所說的,使用ISO格式:new Date('2017-03-02T08:00:00+08:00')

或者

使用moment.js

供參考。

Love MongoDB! Have fun!

回答7:

可以嘗試保存時間戳

標簽: JavaScript
主站蜘蛛池模板: 日本免费一二区视频 | 一级做a爱 | 国产精品国三级国产aⅴ | 毛片激情永久免费 | 国产日韩欧美swag在线观看 | 国产成人精品视频午夜 | 欧美性色黄大片在线观看 | 丝袜美腿在线不卡视频播放 | 欧美性猛交xxx免费看人妖 | 亚洲欧美激情精品一区二区 | 国产一区二区不卡 | 成人国产片免费 | 欧美日韩亚洲在线观看 | 欧美激情欧美狂野欧美精品免费 | 一级做a爱片久久毛片 | 91久久精品国产91性色tv | 亚洲视频免费在线观看 | 国内精品小视频 | 国产中文99视频在线观看 | 日本亚州视频在线八a | 中文字幕在线观看一区二区 | 91精品欧美一区二区三区 | www日本高清视频 | 欧美 日韩 国产 成人 在线观看 | 精品欧美小视频在线观看 | 美女一级ba大片免色野外 | 久久国产精品国产精品 | 二级毛片在线播放 | 一区二区三区四区在线视频 | 亚洲欧美综合一区二区三区四区 | 亚洲素人在线 | 久草国产在线 | 国产一国产一有一级毛片 | 久久精品店 | 99国内精品久久久久久久 | 日韩精品免费一区二区 | 日韩成人在线观看视频 | 视频二区 中文字幕 欧美 | 精品国产不卡一区二区三区 | 亚洲一区在线播放 | 亚洲精品高清在线观看 |