Ошибка агрегации MongoDB Возвращается неверный результат - PullRequest
0 голосов
/ 26 февраля 2019

У меня есть мой объект 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 голосов
/ 26 февраля 2019

Несмотря на то, что не рекомендуется использовать пробел в именах полей в 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" } }
  }
]);
...