FieldPath字段名称可能不包含'。'在$ group

时间:2017-02-24 07:36:04

标签: mongodb

我有以下mongo数据,看起来像这样

{
    eventType : "mousedown",
    eventArgs : {
        type : "touchstart",
        elementId : "id1"
    },
    creationDateTime : ISODate("2017-02-24T07:05:49.986Z")
}

我编写了以下查询来执行组计数。

db.analytics.aggregate
(
    {
        $match :
        {
            $and : 
            [
                {"eventArgs.type" : 'touchstart'}, 
                {eventType : 'mousedown'}, 
                {creationDateTime : {$gte : ISODate("2017-02-24T000:00:00.000Z")}}
            ]
        }
    },
    {
        $group : 
        {
            _id : 
            {
                "eventsArgs.elementId" : "$elementId"
            },
            count : 
            {
                $sum : 1
            }
        }
    }
);

我收到了$group的错误,其中说明了

FieldPath field names may not contain '.'

如果我无法具体说明。'在

        $group : 
        {
            _id : 
            {
                "eventsArgs.elementId" : "$elementId"
            },

这样做的正确方法是什么?

1 个答案:

答案 0 :(得分:2)

由于您只有一个组字段,最好的方法是在该字段上使用_id组密钥,然后创建另一个 $project 管道,该管道将重塑该字段_id键从前一个管道进入您想要的所需子文档。例如

db.analytics.aggregate([
    {
        "$match": {
            "eventArgs.type": 'touchstart', 
            "eventType": 'mousedown', 
            "creationDateTime": { "$gte": ISODate("2017-02-24T000:00:00.000Z") } 
        }
    },
    {
        "$group": {
            "_id": "$eventArgs.elementId",
            "count": { "$sum": 1 }
        }
    },
    {
        "$project": {
            "eventsArgs.elementId": "$_id",
            "count": 1, "_id": 0
        }
    }
]);

以下内容也应该有效:

db.analytics.aggregate([
    {
        "$match": {
            "eventArgs.type": 'touchstart', 
            "eventType": 'mousedown', 
            "creationDateTime": { "$gte": ISODate("2017-02-24T000:00:00.000Z") } 
        }
    },
    {
        "$group": {
            "_id": {
               "eventArgs": {
                   "elementId": "$eventArgs.elementId"
               }
            },
            "count": { "$sum": 1 }
        }
    }
]);