日期范围在聚合管道中不起作用,但在find()中起作用

时间:2019-08-12 22:42:08

标签: mongodb aggregation

我正在尝试按日期范围过滤数据。示例返回不超过14天之前创建的数据。

我可以通过以下操作来做到这一点:

{
    $match: {
        eventTime: { $gte: startTime.toDate(), $lte: endTime.toDate() }
    }
}

eventTime是ISO日期以及startTime和endTime

我正在使用聚合和查找并尝试实现同一件事:

{
            $lookup:
            {
                from: "data",
                let: { dataId: "$dataId", patientId: "$patientId" },
                pipeline: [
                    {
                        $match:
                        {
                            $expr:
                            {
                                $and:
                                    [
                                        { $eq: ["$patientId", patientId] },
                                        { $eq: ["$dataId", "$$dataId"] },
                                        { $gte: ["$eventTime", startTime.toDate()] },
                                        { $lte: ["$eventTime", endTime.toDate()] },
                                    ]
                            }
                        }
                    }
                ],
                as: "data"
            }
        }

但是不返回任何数据结果。如果删除日期,我将基于dataId和Patient获得所有正确的数据。所以联接正在工作..但是以某种方式日期范围却没有。

再次,eventTime和startTime和endTime均为ISO日期。 例子:

let endTime = Moment(new Date());
let startTime = Moment().subtract(days, "days");

"eventTime": "2019-08-07T03:37:40.738Z"

 startTime  "2019-07-30T00:02:11.611Z"
 endTime  "2019-08-13T00:02:11.610Z"

End time is 'today' 
so in the example here the data time is between the two dates and should be returned.

我看着那里:https://docs.mongodb.com/manual/reference/operator/aggregation/gte/ 它应该工作..但不是这样

我尝试过:

{eventTime: { '$gte': new Date(startTime), $lte: new Date(endTime)}}
and I get:
MongoError: An object representing an expression must have exactly one field: { $gte: new Date(1564495211043), $lte: new Date(1565704811042) }

也尝试过:

{ eventTime: {'$gte': new Date(startTime)}}

and get:

MongoError: Expression $gte takes exactly 2 arguments. 1 were passed in.

也尝试过:

{ $eventTime: {'$gte': new Date(startTime)}}, {$eventTime: {'$lte': new Date(endTime)}}

and get: MongoError: Unrecognized expression '$eventTime'

任何见识肯定会得到赞赏

1 个答案:

答案 0 :(得分:0)

我能够通过toDate使它工作:

{
                        $match:
                        {
                            $expr:
                            {
                                $and:
                                    [
                                        { $eq: ["$patientId", patientId] },
                                        { $eq: ["$dataId", "iraeOverallAlert"] },
                                        { "$gte": [ {$toDate: "$eventTime"}, startTime.toDate()] },
                                        { "$lte": [ {$toDate: "$eventTime"}, endTime.toDate()] },

                                    ]
                            }
                        }
                    },

注意:这在查找中不是必需的,但是以某种方式需要使用聚合。毫无疑问,是的,要反复试验。