我是Node.Js和MongoDB的新手。我正在获取日期作为CreatedDate:2018-09-06T06:14:53.111Z。在输出中,我试图显示为“ MM / DD / YYYY”。
这是我的代码正在获取最近60天的数据表单集合。
var today = new Date();
today.setDate(today.getDate() - 60);
ODSCase.find({ UserGUID: req.UserGUID ,CreatedDate:{"$gte":new Date(today)} }).sort({ModifiedDate: -1})
.exec()
.then(doc => {
res.status(200).json(doc);
})
.catch(err =>{ err500.err500(err,req,res,next);});
输出:
{
"_id": "5b9242aed7ae250c74325362",
"CustomerGUID": "ee1ac5c7-c0f9-466c-8859-95dc1fcd0334",
"InstanceGUID": "878aee54-1b95-46d1-9e26-b9eaea9f9cd4",
"UserGUID": "f0272467-3ec5-48f7-5553-987900b57a11",
"CaseNumber": 1536311981016,
"CaseStatus": "New",
"CampaignID": "66336533-3765-3266-4d43-382f392f3230",
"CreatedDate": "2018-09-07T09:19:42.586Z",
"CreatedBy": "f0272467-3ec5-48f7-5553-987900b57a11",
"ModifiedDate": "2018-09-07T09:19:42.586Z",
"ModifiedBy": "f0272467-3ec5-48f7-5553-987900b57a11",
"IsDeleted": false,
"Source": "Dev",
"__v": 0
},
最佳答案
考虑运行一条聚合管道,它允许您使用诸如$dateToString
之类的运算符,这些运算符可以将日期转换为所需的格式。
例如,可以使用聚合框架运行与上述相同的查询:
let today = new Date();
today.setDate(today.getDate() - 60);
const date = new Date(today);
ODSCase.aggregate([
{ '$match': {
'UserGUID': req.UserGUID,
'CreatedDate': { '$gte': date }
} },
{ '$sort': { 'ModifiedDate': -1 } },
{ '$addFields': {
'CreatedDate': {
'$dateToString': {
'format': '%m/%d/%Y',
'date': '$CreatedDate'
}
}
} }
])
.exec()
.then(doc => {
res.status(200).json(doc);
})
.catch(err => err500.err500(err, req, res, next) );
您还可以使用出色的Moment.js JavaScript date library来创建查询中使用的日期对象:
const moment = require('moment');
const date = moment().subtract(60, 'days').toDate(); // or...
const date = moment().add(-60, 'days').toDate();