Javascript 如何根据MongoDB中的day createdAt添加文档值?
我需要在创建日期为当前日期的每个文档的“value”属性中添加一个值,该文档的“finished”属性为true,该文档的“value”和“period.check_out”属性为true 到目前为止,我已经能够选择所有具有“period.check_out”属性的文档,并对这些值求和。问题是选择当天的文档。我试着在很多方面按天分类,但我没有得到答案 我启用了nas数据库模型,因此每当我创建新文档时,它都会自动为我添加createdAt、updatedAt和_v 文档示例:Javascript 如何根据MongoDB中的day createdAt添加文档值?,javascript,node.js,mongodb,express,mongoose,Javascript,Node.js,Mongodb,Express,Mongoose,我需要在创建日期为当前日期的每个文档的“value”属性中添加一个值,该文档的“finished”属性为true,该文档的“value”和“period.check_out”属性为true 到目前为止,我已经能够选择所有具有“period.check_out”属性的文档,并对这些值求和。问题是选择当天的文档。我试着在很多方面按天分类,但我没有得到答案 我启用了nas数据库模型,因此每当我创建新文档时,它都会自动为我添加createdAt、updatedAt和_v 文档示例: [ {
[
{
"_id": "1",
"client": {
"name": "raul germano"
},
"parking": {
"_id": "5d8bfe395e0a822b143fd68d",
"value": 2.59,
"name": "pro parking oficial"
},
"finished": false,
"createdAt": "2019-09-25T23:54:32.802Z",
"updatedAt": "2019-09-25T23:54:32.802Z"
},
{
"_id": "2",
"client": {
"name": "raul vitor"
},
"parking": {
"_id": "5d8bfe395e0a822b143fd68d",
"value": 2.32,
"name": "pro parking oficial"
},
"period": {
"check_in": {
"user": "caboco",
"moment": "2019-09-25T00:05:36.273Z"
},
"check_out": {
"user": "outro caboco",
"moment": "2019-09-25T00:09:56.506Z"
}
},
"hours": 0.07,
"value": 0.17,
"finished": true,
"createdAt": "2019-09-26T23:54:33.463Z",
"updatedAt": "2019-09-26T23:54:33.463Z"
},
{
"_id": "3",
"client": {
"name": "raul germano"
},
"parking": {
"_id": "5d8bfe395e0a822b143fd68d",
"value": 2.60,
"name": "pro parking oficial"
},
"finished": true,
"createdAt": "2019-09-25T23:54:33.463Z",
"updatedAt": "2019-09-25T23:54:33.463Z",
"period": {
"check_in": {
"user": "caboco",
"moment": "2019-09-25T00:05:36.273Z"
},
"check_out": {
"user": "outro caboco",
"moment": "2019-09-25T00:09:56.506Z"
}
},
"hours": 0.09,
"value": 0.23
}
]
当前查询:
collection.aggregate([
{
$match: {
'period.check_out': {
$exists: true
},
createdAt: {
$gte: new Date("2019-09-24")
$lt: new Date("2019-09-25")
}
}
},
{
$unwind: '$parking'
},
{
$match: {
'parking._id': Types.ObjectId(parking_id)
}
},
{
$group: {
_id: Types.ObjectId(parking_id),
total: {
$sum: '$value'
}
}
}
])
这样他就可以选择最后24小时
基于上述文档,我只需要选择_id“1”和“2”文档。因此,考虑到“2019-09-26”是当前日期,尝试将您的$match替换为以下内容:
{
$match: {
'period.check_out': {
$exists: true
},
createdAt: {
$gte: new Date('2019-09-26'),
$lte: new Date(),
}
}
},
您匹配的是:$gte:2019-09-24T00:00:00.000Z,$lte:2019-09-25T00:00:00.000Z。我不认为那是目前的日期。
相反,您需要匹配的是“2019-09-24T00:00:00.000Z”-当前时间。但“新日期('2019-09-26')”将返回“Wed Sep 25 2019 21:00:00 GMT-0300(Horário Padrão de Brasília)”好的。然后你需要找到一个解决办法,找到一天中的第一秒,即“2019-09-26T00:00:00.000Z”。