更改Sequelize时区

12

我想在nodejs中制作restful应用。

服务器:centos 7 64x

数据库:postgresql

附加:express,sequelize

表:带有时区的日期时间

当使用sequelize从数据库选择行时,created_at列会给出错误的时间。时间增加了5个小时。

我将centos的时区配置更改为+5(塔什干/亚洲),同时更改了postgresql的时区配置为+5,在数据库中Datetime的显示是正确的。

但是当我选择它时,它转换成这样:

"createdAt": "2018-08-12T17:57:20.508Z"

在数据库列中显示为:

2018-08-12 22:57:20.508+05

config.json

"development": {
    "username": "postgres",
    "password": "postgres",
    "database": "zablet",
    "host": "127.0.0.1",
    "dialect": "postgres",
    "timezone": "Tashkent/Ashgabat",
    "define": {
        "charset": "utf8",
        "dialectOptions": {
            "collate": "utf8_general_ci"
        },
        "freezeTableName": true
    }
}

index.js

'use strict';
var fs = require('fs');
var path = require('path');

var Sequelize = require('sequelize');
var basename = path.basename(__filename);
var env = process.env.NODE_ENV || 'development';
var config = require('../config/config.json')[env];
var db = {};
if (config.use_env_variable) {
    var sequelize = new Sequelize(process.env[config.use_env_variable], config);
} else {
    var sequelize = new Sequelize(config.database, config.username, config.password, config);
}
fs
    .readdirSync(__dirname)
    .filter(file => {
        return (file.indexOf('.') !== 0) && (file !== basename) && (file.slice(-3) === '.js');
    })
    .forEach(file => {
        var model = sequelize['import'](path.join(__dirname, file));
        db[model.name] = model;
    });
Object.keys(db).forEach(modelName => {
    if (db[modelName].associate) {
        db[modelName].associate(db);
    }
});
db.sequelize = sequelize;
db.Sequelize = Sequelize;
module.exports = db;

更新的config.json

{
    "development": {
    "username": "postgres",
    "password": "postgres",
    "database": "postgres",
    "host": "127.0.0.1",
    "dialect": "postgres",
    "define": {
        "charset": "utf8",
        "dialectOptions": {
            "collate": "utf8_general_ci"
        },
        "freezeTableName": true
    },
    "dialectOptions": {
        "useUTC": false
    },
    "timezone": "+05:00"
}
}

如何在正确的时区格式中从数据库中选择行?


2
如果你正在构建REST API,最好在数据库中以UTC存储日期,然后在客户端进行转换。为什么?想象一下,如果你的API有来自不同时区的用户...那就是了,你的API只会变得不够用。 - jayarjo
2个回答

12

这是因为你只设置了写入数据库的时区,而没有设置读取时区。这样是正确的。我正在使用这种方式。

development: {
    username: 'postgres',
    password: 'postgres',
    database: 'YOUR_DATABASE_NAME',
    host: '127.0.0.1',
    port: 5432,
    dialect: 'postgres',
    dialectOptions: {
      useUTC: false, // for reading from database
    },
    timezone: '+05:30', // for writing to database
  },
如果仍然无法正常工作,那么请在 connection.js 中的 sequelize 构造器中添加以下属性。
dialectOptions:{useUTC:false},timezone:"+05:30"

与以下代码类似:

const sequelize = new Sequelize("DB",'USER','PWD',{host:'127.0.0.1',dialect:"mysql",operatorsAliases:0,timezone:"+05:30"})

你所看到的是我正在使用的。它对我来说很好用。 - Rahul Sharma
你想在所需的时区中查看保存的数据。为此,您必须在数据库选项中设置时区。 如果您在上述配置之后查询,它将始终返回与您的时区查询相对应的结果。 - Rahul Sharma
不对。也许我漏掉了其他的配置? - Benfactor
你能像我定义的那样定义dialectOption吗? - Rahul Sharma
我把它放在更新的问题下面的定义中。也许是postgresql的问题? - Benfactor
@RahulSharma,如果我保存时区为GMT-8,那么在我的phpmyadmin数据库中不应该看到不同的时间吗? - Luke Galea

1

在配置JSON中使用

"production": {
    "username": "xyz",
    "password": "",
    "database": "dbname",
    "host": "127.0.0.1",
    "dialect": "mysql",
    "port": 123,
    "dialectOptions": {
      "useUTC": false 
    },
    "timezone": "+05:30"
}

你的回答可以通过添加更多关于代码的信息以及它如何帮助提问者来改进。 - Tyler2P

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接