Подсчет элементов массива, соответствующих условию - PullRequest
0 голосов
/ 04 сентября 2018

У меня есть коллекция mongoDB под названием «конференция» с массивом участников, как показано ниже:

[
  {
    "_id" : 5b894357a0c84d5a5d221f25, 
    "conferenceName" : "myFirstConference",
    "startDate" : 1535722327, 
    "endDate" : 1535722420,
    "participants" : [
        {
            "name" : "user1", 
            "origin" : "internal", 
            "ip" : "192.168.0.2"
        },
        {
            "name" : "user2", 
            "origin" : "external", 
            "ip" : "172.20.0.3"
        }, 
    ]
  },
  ...
]

Я бы хотел получить следующий результат:

[
  {
     "conferenceName" : "myFirstConference",
     "startDate" : 1535722327, 
     "endDate" : 1535722420,
     "internalUsersCount" : 1
     "externalUsersCount" : 1,
  },
  ...
]

Я попробовал запрос ниже, но он не работает:

db.getCollection("conference").aggregate([
   {
     $addFields: {
       internalUsersCount : {
            $size : { "$participants" : {$elemMatch : { origin : "internal" }}}
         },
       externalUsersCount : {
            $size : { "$participants" : {$elemMatch : { origin : "external" }}}
         }         
     }
   }
])

Как можно подсчитать элементы массива "участник", которые соответствуют {"origin": "internal"} и {"origin": "external"} ?

1 Ответ

0 голосов
/ 04 сентября 2018

Вам нужно использовать агрегацию $filter для фильтрации external источника и internal источника вместе с $size агрегация для расчета длины массивов.

как то так

db.collection.aggregate([
  { "$project": {
    "conferenceName": 1,
    "startDate": 1,
    "endDate": 1,
    "internalUsersCount": {
      "$size": {
        "$filter": {
          "input": "$participants",
          "as": "part",
          "cond": { "$eq": ["$$part.origin", "internal"]}
        }
      }
    },
    "externalUsersCount": {
      "$size": {
        "$filter": {
          "input": "$participants",
          "as": "part",
          "cond": { "$eq": ["$$part.origin", "external"] }
        }
      }
    }
  }}
])

выход

[
  {
    "conferenceName": "myFirstConference",
    "endDate": 1535722420,
    "externalUsersCount": 1,
    "internalUsersCount": 1,
    "startDate": 1535722327
  }
]
...