Computer >> 컴퓨터 >  >> 프로그램 작성 >> MongoDB

특정 필드의 값을 기반으로 배열의 문서를 어떻게 계산합니까?

<시간/>

이러한 일치 및 개수에는 MongoDB에서 $match를 사용합니다. 문서로 컬렉션을 만들자 −

> db.demo726.insertOne(
...    {
...       id:101,
...       "details": [
...          {
...             Name:"Chris"
...
...          },
...          {
...             Name:"Chris"
...
...          },
...          {
...             Name:"Bob"
...          }
...       ]
...    }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5eab318643417811278f5894")
}

find() 메서드를 사용하여 컬렉션의 모든 문서 표시 -

> db.demo726.find();

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : ObjectId("5eab318643417811278f5894"), "id" : 101, "details" : [ { "Name" : "Chris" }, { "Name" : "Chris" }, { "Name" : "Bob" } ] }

다음은 MongoDB의 특정 필드 값을 기반으로 배열의 문서를 계산하는 쿼리입니다 -

> db.demo726.aggregate([
...
...    { $unwind: '$details' },
...
...    { $match: { 'details.Name': "Chris"} },
...       { $group: {
...          _id: "$Name",
...          Total_Value: { $sum: 1 }
...       }
...    }
... ]);

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : null, "Total_Value" : 2 }