요소를 가져오려면 $(위치) 연산자와 함께 $pull을 사용합니다. 문서로 컬렉션을 만들자 −
> db.demo679.insertOne( ... { ... id:1, ... "details": [ ... { ... CountryName:"US", ... "information": [ ... ... { "Name": "Chris", "FirstName": "Name=Chris" }, ... ... {"Name": "Bob", "FirstName": "Name=Bob" } ... ] ... }, ... { ... CountryName:"UK", ... "information": [ ... ... { "Name": "Robert", "FirstName": "Name=Robert" }, ... ... {"Name": "Sam", "FirstName": "Name=Sam" } ... ] ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5ea442cf04263e90dac943fd") }
find() 메서드를 사용하여 컬렉션의 모든 문서 표시 -
> db.demo679.find();
이것은 다음과 같은 출력을 생성합니다 -
{ "_id" : ObjectId("5ea442cf04263e90dac943fd"), "id" : 1, "details" : [ { "CountryName" : "US", "information" : [ { "Name" : "Chris", "FirstName" : "Name=Chris" }, { "Name" : "Bob", "FirstName" : "Name=Bob" } ] }, { "CountryName" : "UK", "information" : [ { "Name" : "Robert", "FirstName" : "Name=Robert" }, { "Name" : "Sam", "FirstName" : "Name=Sam" } ] } ] }
다음은 MongoDB에서 하위 배열의 하위 요소를 가져오는 쿼리입니다. -
> db.demo679.update( ... { "details.CountryName":"US" }, ... { $pull: { 'details.$.information': { "Name" : "Bob", "FirstName" : "Name=Bob" } } } ... ); WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
find() 메서드를 사용하여 컬렉션의 모든 문서 표시 -
> db.demo679.find().pretty();
이것은 다음과 같은 출력을 생성합니다 -
{ "_id" : ObjectId("5ea442cf04263e90dac943fd"), "id" : 1, "details" : [ { "CountryName" : "US", "information" : [ { "Name" : "Chris", "FirstName" : "Name=Chris" } ] }, { "CountryName" : "UK", "information" : [ { "Name" : "Robert", "FirstName" : "Name=Robert" }, { "Name" : "Sam", "FirstName" : "Name=Sam" } ] } ] }