MongoDB聚合错误返回错误结果

时间:2019-02-26 16:33:11

标签: mongodb aggregation

我有这样的json对象

{
    "_id": "5c2e811154855c0012308f00",
    "__pclass": "QXRzXFByb2plY3RcTW9kZWxcUHJvamVjdA==",
    "id": 44328,
    "name": "Test project via postman2//2",
    "address": "some random address",
    "area": null,
    "bidDate": null,
    "building": {
        "name": "Health Care Facilities",
        "type": "Dental Clinic"
    },
    "collaborators": [],
    "createdBy": {
        "user": {
            "id": 7662036,
            "name": "Someone Here"
        },
        "firm": {
            "id": 2520967,
            "type": "ATS"
        }
    },
    "createdDate": "2019-01-03T21:39:29Z",
    "customers": [],
    "doneBy": null,
    "file": null,
    "firm": {
        "id": 1,
        "name": "MyFirm"
    },
    "leadSource": {
        "name": "dontknow",
        "number": "93794497"
    },
    "location": {
        "id": null,
        "city": {
            "id": 567,
            "name": "Bahamas"
        },
        "country": {
            "id": 38,
            "name": "Canada"
        },
        "province": {
            "id": 7,
            "name": "British Columbia"
        }
    },
    "modifiedBy": null,
    "modifiedDate": null,
    "projectPhase": {
        "id": 1,
        "name": "pre-design"
    },
    "quotes": [{
        "id": 19,
        "opportunityValues": {
            "Key1": 100,
            "Key2 Key2": 100,
            "Key3 Key3 Key3": 200,
    }
    }],
    "specForecast": [],
    "specIds": [],
    "tags": [],
    "valuation": "something"
}

我正在尝试在MongoDB中使用此查询进行汇总。我的聚合密钥深度为4级,还包含空格。在所有在线示例中,向我展示了第一级的汇总。查看在线代码,我尝试用我的第4级深度键再次重申该代码。

db.mydata.aggregate([
  {$match: {"id": 44328 } } ,
  {$group: { _id: "$quotes.id",
    totalKey2:{ $sum: "$quotes.opportunityValues.Key2 Key2"},
    totalKey3:{ $sum: "$quotes.opportunityValues.Key3 Key3 Key3"}
  }
  }
]);

这应该返回

_id    totalKey2   totalKey3
 0 19    100         300

但它正在返回

_id    totalKey2   totalKey3
 0 19      0         0

我在做什么错了?

1 个答案:

答案 0 :(得分:0)

尽管不建议在Mongo的字段名称中使用空格,但可以正常使用。

查询的问题是“引号”是一个数组,您应该先对其进行展开,然后再对其进行分组。

这按预期工作:

db.mydata.aggregate([
  { $match: { "id": 44328 } } ,
  { $unwind: "$quotes" },
  { $group: { _id: "$quotes.id",
    totalKey2:{ $sum: "$quotes.opportunityValues.Key2 Key2" },
    totalKey3:{ $sum: "$quotes.opportunityValues.Key3 Key3 Key3" } }
  }
]);