Javascript 如何根据MongoDB中的day createdAt添加文档值?

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 文档示例: [ {

我需要在创建日期为当前日期的每个文档的“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”。