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

지정된 값이 배열에 있는 경우 반환된 개체에 true 부울 필드를 추가합니다. NULL 또는 다른 값의 경우 false를 설정합니다.

<시간/>

이를 위해 $ifNull을 사용합니다. 표현식을 평가하고 표현식이 null이 아닌 값으로 평가되는 경우 표현식의 값을 반환합니다. 먼저 문서로 컬렉션을 만들어 보겠습니다. −

> db.demo542.insertOne({"ListOfName":["Chris","David"]});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabc6ef4dcbee04fbbc17")
}
> db.demo542.insertOne({"ListOfName":null});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabc8ef4dcbee04fbbc18")
}
> db.demo542.insertOne({"ListOfName":["David"]});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabd3ef4dcbee04fbbc19")
}
> db.demo542.insertOne({"Name":"John"});{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e8cabdaef4dcbee04fbbc1a")
}

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

> db.demo542.find();

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

{ "_id" : ObjectId("5e8cabc6ef4dcbee04fbbc17"), "ListOfName" : [ "Chris", "David" ] }
{ "_id" : ObjectId("5e8cabc8ef4dcbee04fbbc18"), "ListOfName" : null }
{ "_id" : ObjectId("5e8cabd3ef4dcbee04fbbc19"), "ListOfName" : [ "David" ] }
{ "_id" : ObjectId("5e8cabdaef4dcbee04fbbc1a"), "Name" : "John" }

다음은 특정 값을 확인하는 쿼리입니다 -

> var id = "David";
> db.demo542.aggregate([
...    {
...       "$project": {
...          "matched": {
...             "$eq": [
...                {
...                   "$size": {
...                      "$ifNull": [
...                         { "$setIntersection": [ "$ListOfName", [id] ] },
...                         []
...                      ]
...                   }
...                },
...                1
...             ]
...          }
...       }
...    }
... ])

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

{ "_id" : ObjectId("5e8cabc6ef4dcbee04fbbc17"), "matched" : true }
{ "_id" : ObjectId("5e8cabc8ef4dcbee04fbbc18"), "matched" : false }
{ "_id" : ObjectId("5e8cabd3ef4dcbee04fbbc19"), "matched" : true }
{ "_id" : ObjectId("5e8cabdaef4dcbee04fbbc1a"), "matched" : false }