久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

問題描述

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

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

這是我存入的數(shù)據(jù):

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

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

小弟這里先謝過!

問題解答

回答1:

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

回答2:

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

回答3:

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

回答4:

存成unix時間戳吧,這樣就不會有啥問題了,取出來的時候 根據(jù)時區(qū)去處理轉(zhuǎn)換就可以了

回答5:

你在把那個iso時間new Date回來就好了,存的是iso標(biāo)準(zhǔn)時間,new Date的時候回自動轉(zhuǎn)成本地時區(qū)

回答6:

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

或者

使用moment.js

供參考。

Love MongoDB! Have fun!

回答7:

可以嘗試保存時間戳

標(biāo)簽: JavaScript
主站蜘蛛池模板: 呼玛县| 岳普湖县| 巧家县| 项城市| 平顶山市| 余江县| 乌兰县| 达尔| 阳高县| 塔河县| 察隅县| 金沙县| 凭祥市| 武夷山市| 金山区| 措美县| 平顶山市| 通州市| 浑源县| 临邑县| 昌平区| 桐柏县| 阿荣旗| 吉首市| 泊头市| 唐河县| 若尔盖县| 文安县| 巴东县| 修文县| 奈曼旗| 阜宁县| 平度市| 罗田县| 水城县| 福鼎市| 宜昌市| 乐昌市| 宜兴市| 文安县| 南岸区|