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

MongoDB에서 배열을 기반으로 문서를 필터링하는 방법은 무엇입니까?


배열을 기반으로 문서를 필터링하려면 $elemMatch를 사용하십시오. $elemMatch 연산자는 배열 필드가 포함된 문서와 일치합니다.

문서로 컬렉션을 만들자 −

> db.demo453.insertOne(
... { _id: 101, details: [ { Name: "David", Marks: 60 }, { Name: "Mike", Marks: 55} ] }
... )
{ "acknowledged" : true, "insertedId" : 101 }
> db.demo453.insertOne(
... { _id: 102, details: [ { Name: "Bob", Marks: 80 }, { Name: "Sam", Marks: 78} ] }
... )
{ "acknowledged" : true, "insertedId" : 102 }
> db.demo453.insertOne(
... { _id: 103, details: [ { Name: "Carol", Marks: 67 }, { Name: "John", Marks: 79} ] }
... )
{ "acknowledged" : true, "insertedId" : 103 }

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

> db.demo453.find();

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

{ "_id" : 101, "details" : [ { "Name" : "David", "Marks" : 60 }, { "Name" : "Mike", "Marks" : 55 } ] }
{ "_id" : 102, "details" : [ { "Name" : "Bob", "Marks" : 80 }, { "Name" : "Sam", "Marks" : 78 } ] }
{ "_id" : 103, "details" : [ { "Name" : "Carol", "Marks" : 67 }, { "Name" : "John", "Marks" : 79 } ] }

다음은 배열을 기반으로 문서를 필터링하는 쿼리입니다 -

> db.demo453.find(
... { details: { $elemMatch: {Marks: { $gte: 75 } } } }
... )

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

{ "_id" : 102, "details" : [ { "Name" : "Bob", "Marks" : 80 }, { "Name" : "Sam", "Marks" : 78 } ] }
{ "_id" : 103, "details" : [ { "Name" : "Carol", "Marks" : 67 }, { "Name" : "John", "Marks" : 79 } ] }