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

MongoDB 쿼리에서 하위 문서에 어떻게 액세스합니까?

<시간/>

MongoDB의 하위 문서에 액세스하려면 점 표기법과 함께 find()를 사용하십시오. 문서로 컬렉션을 만들자 −

> db.demo670.insertOne({
... id:101,
... "details":
... {
... Name:"Chris",
... Age:21,
... CountryName:"US",
... SubjectName:"MongoDB"
... }
... }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea3e31d04263e90dac943de")
}
> db.demo670.insertOne({ id:102, "details": { Name:"David", Age:22, CountryName:"UK", SubjectName:"MySQL" } } );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ea3e33604263e90dac943df")
}

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

> db.demo670.find();

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

{ "_id" : ObjectId("5ea3e31d04263e90dac943de"), "id" : 101, "details" : { "Name" : "Chris", "Age" : 21, "CountryName" : "US", "SubjectName" : "MongoDB" } }
{ "_id" : ObjectId("5ea3e33604263e90dac943df"), "id" : 102, "details" : { "Name" : "David", "Age" : 22, "CountryName" : "UK", "SubjectName" : "MySQL" } }

다음은 하위 문서에 액세스하는 쿼리입니다 -

> db.demo670.find({"details.SubjectName":"MongoDB"},{"details.CountryName":1});7

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

{ "_id" : ObjectId("5ea3e31d04263e90dac943de"), "details" : { "CountryName" : "US" } }