Node.js中sequelize時區(qū)的配置方法
基本概念
我們先來介紹一些可能當(dāng)年在地理課上學(xué)習(xí)過的基本概念。
說起來,時間真是一個神奇的東西。以前人們通過觀察太陽的位置來決定時間(比如:使用日晷),這就使得不同經(jīng)緯度的地區(qū)時間是不一樣的。后來人們進一步規(guī)定以子午線為中心,向東西兩側(cè)延伸,每 15 度劃分一個時區(qū),剛好是 24 個時區(qū)。然后因為一天有 24 小時,地球自轉(zhuǎn)一圈是 360 度,360 度 / 24 小時 = 15 度/小時,所以每差一個時區(qū),時間就差一個小時。
最開始的標(biāo)準(zhǔn)時間(子午線中心處的時間)是英國倫敦的皇家格林威治天文臺的標(biāo)準(zhǔn)時間(因為它剛好在本初子午線經(jīng)過的地方),這就是我們常說的 GMT(Greenwich Mean Time)。然后其他各個時區(qū)根據(jù)標(biāo)準(zhǔn)時間確定自己的時間,往東的時區(qū)時間晚(表示為 GMT+hh:mm)、往西的時區(qū)時間早(表示為 GMT-hh:mm)。比如,中國標(biāo)準(zhǔn)時間是東八區(qū),我們的時間就總是比 GMT 時間晚 8 小時,他們在凌晨 1 點,我們已經(jīng)是早晨 9 點了。
但是 GMT 其實是根據(jù)地球自轉(zhuǎn)、公轉(zhuǎn)計算的(太陽每天經(jīng)過英國倫敦皇家格林威治天文臺的時間為中午 12 點),不是非常準(zhǔn)確,于是后面提出了根據(jù)原子鐘計算的標(biāo)準(zhǔn)時間 UTC(Coordinated Universal Time)。
一般情況下,GMT 和 UTC 可以互換,但是實際上,GMT 是一個時區(qū),而 UTC 是一個時間標(biāo)準(zhǔn)。
下面開始本文的正文:
Node.js sequelize時區(qū)配置
sequelize 默認(rèn)情況下,保存日期時會轉(zhuǎn)換成 +00:00時區(qū),例如
提交數(shù)據(jù):
time=2017-07-17 16:52:12
數(shù)據(jù)庫中會保存成
2017-07-17 08:52:12
解決方式:
sequelize時配置時區(qū)
timezone: '+08:00'
如:
const sequelize = new Sequelize(config.database, config.username, config.password, {
host: config.host,
port: config.port,
dialect: 'mysql',
pool: {
max: 5,
min: 0,
idle: 10000
},
timezone: '+08:00'
});
PS:鏈接的所有數(shù)據(jù)庫(讀和寫)都要設(shè)置合適的時區(qū),否則會出現(xiàn)時間寫入不一致的情況
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Node.js數(shù)據(jù)庫操作之連接MySQL數(shù)據(jù)庫(一)
前一陣在做項目的時候,需要通過nodejs連接到MySQL數(shù)據(jù)庫,于是簡單地學(xué)習(xí)了一下MySQL這個庫,分享一些學(xué)習(xí)心得給大家,希望對大家有幫助。下面這篇文章主要介紹了Node.js數(shù)據(jù)庫操作之連接MySQL數(shù)據(jù)庫的相關(guān)資料,需要的朋友可以參考下。2017-03-03
Node.js如何實現(xiàn)MySQL數(shù)據(jù)庫連接池
文章介紹了Node.js中實現(xiàn)MySQL數(shù)據(jù)庫連接池的方法,通過預(yù)先建立和管理數(shù)據(jù)庫連接對象,優(yōu)化數(shù)據(jù)庫連接的使用效率2024-11-11
nodejs+mongodb aggregate級聯(lián)查詢操作示例
這篇文章主要介紹了nodejs+mongodb aggregate級聯(lián)查詢操作,結(jié)合實例形式分析了基于nodejs的mongodb數(shù)據(jù)庫級聯(lián)查詢相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
在Nodejs中實現(xiàn)一個緩存系統(tǒng)的方法詳解
在數(shù)據(jù)庫查詢遇到瓶頸時,我們通??梢圆捎镁彺鎭硖嵘樵兯俣?同時緩解數(shù)據(jù)庫壓力,在一些簡單場景中,我們也可以自己實現(xiàn)一個緩存系統(tǒng),避免使用額外的緩存中間件,這篇文章將帶你一步步實現(xiàn)一個完善的緩存系統(tǒng),需要的朋友可以參考下2024-03-03
Ubuntu 16.04 64位中搭建Node.js開發(fā)環(huán)境教程
如果想要在Ubuntu 16.04上安裝Node.js的話,這篇文章對你來說肯定很重要。Node.js從本質(zhì)上來說就是一個運行在服務(wù)端上的封裝好了輸入輸出流的javascript程序。本文給大家詳細(xì)介紹了在Ubuntu 16.04 64位搭建Node.js開發(fā)環(huán)境的步驟,有需要的朋友們可以參考學(xué)習(xí)。2016-10-10

