mongoose和express.js中的日期冲突

时间:2016-04-12 17:34:53

标签: javascript node.js mongodb mongoose momentjs

当我使用Date而不是String声明我的模式时会出现问题。

案例I:

var MySchema = new Schema({
    created_at: {type: String, default: ''}
});

通过这个shema声明,我使用moment.js moment-timezone模块来声明亚洲/加尔各答时区的当前时间。

var tmoment = require('moment-timezone');
var currentTime = tmoment().tz('Asia/Kolkata').format('llll');

我能够得到正确的时间。

案例II:

var MySchema = new Schema({
    created_at: {type: Date, default: ''}
});

通过这个shema声明,我使用moment.js moment-timezone模块来声明亚洲/加尔各答时区的当前时间。

var tmoment = require('moment-timezone');
var currentTime = tmoment().tz('Asia/Kolkata').format('llll');

现在时间不按时区来了。我甚至尝试过以下声明

var tmoment = require('moment-timezone');
var currentTime = tmoment().tz('Asia/Kolkata').format();

但是无法找到解决方案。

2 个答案:

答案 0 :(得分:0)

将日期保存到mongo数据库时,无论时区如何,都可以直接保存javascript Date对象。 (使用Date类型,如案例2中所示。)然后,您可以使用片刻显示日期,无论您需要什么时区。

保存对象:

var id = ...
var saveReq = new RequestModel({ _id: id, created_at: new Date() });
saveReq.save(function (err, result) {
  // ...
});

要从数据库中读取对象,然后显示本地化的日期字符串:

var tmoment = require('moment-timezone');
RequestModel.findOne({_id: id}, function (err, doc) {
  if(err) {} // ...
  var created = doc.created_at;
  var display = tmoment(created).tz('Asia/Kolkata').format('llll');
  console.log(display);
});

答案 1 :(得分:0)

将服务器时区更改为您当地的时区。