이를 위해 $nin 연산자를 사용할 수 있습니다. 개념을 이해하기 위해 문서로 컬렉션을 만들어 보겠습니다. 문서로 컬렉션을 생성하는 쿼리는 다음과 같습니다 -
> db.documentWithAParticularFieldValueDemo.insertOne(
... {
...
... "StudentId" : 101,
... "StudentDetails" :
... [
... {
... "TheoryMarks": 78,
... "PracticalMarks": 91
... },
... {
... "TheoryMarks": 75,
... "PracticalMarks": 75
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8edab72f684a30fbdfd586")
}
> db.documentWithAParticularFieldValueDemo.insertOne(
...
... { "StudentId" : 102,
... "StudentDetails" : [
... {
... "TheoryMarks": 91,
... "PracticalMarks": 91
... },
... {
... "TheoryMarks": 75,
... "PracticalMarks": 75
... }
... ]
... }
... );
{
"acknowledged" : true,
"insertedId" : ObjectId("5c8edaf12f684a30fbdfd587")
} find() 메서드를 사용하여 컬렉션의 모든 문서를 표시합니다. 쿼리는 다음과 같습니다 -
> db.documentWithAParticularFieldValueDemo.find().pretty();
다음은 출력입니다 -
{
"_id" : ObjectId("5c8edab72f684a30fbdfd586"),
"StudentId" : 101,
"StudentDetails" : [
{
"TheoryMarks" : 78,
"PracticalMarks" : 91
},
{
"TheoryMarks" : 75,
"PracticalMarks" : 75
}
]
}
{
"_id" : ObjectId("5c8edaf12f684a30fbdfd587"),
"StudentId" : 102,
"StudentDetails" : [
{
"TheoryMarks" : 91,
"PracticalMarks" : 91
},
{
"TheoryMarks" : 75,
"PracticalMarks" : 75
}
]
} 다음은 MongoDB에서 특정 필드 값을 가진 문서를 포함하지 않는 배열이 있는 문서를 찾는 쿼리입니다 -
> db.documentWithAParticularFieldValueDemo.find({'StudentDetails.TheoryMarks': {$nin: [78]}}).pretty(); 다음은 출력입니다 -
{
"_id" : ObjectId("5c8edaf12f684a30fbdfd587"),
"StudentId" : 102,
"StudentDetails" : [
{
"TheoryMarks" : 91,
"PracticalMarks" : 91
},
{
"TheoryMarks" : 75,
"PracticalMarks" : 75
}
]
}