javascript - JS new Date() 儲存到 mongodb 中會早8個小時,我們這裡是東八區,mongodb 保存的是格林尼治時間
我想大声告诉你
我想大声告诉你 2017-06-05 11:08:46
0
7
1657

我用的 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 有對應的處理方法嗎?

小弟這裡先謝過!

我想大声告诉你
我想大声告诉你

全部回覆(7)
伊谢尔伦

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

漂亮男人

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

滿天的星座

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

世界只因有你

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

洪涛

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

我想大声告诉你

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

使用moment.js

供參考。

Love MongoDB! Have fun!


世界只因有你

可以嘗試保存時間戳

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板