javascript - JS new Date() 保存到 mongodb 中會早8個小時,我們這里是東八區,mongodb 保存的是格林尼治時間
問題描述
我用的 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 中后存的時間會早八個小時:‘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:可以嘗試保存時間戳
