我能夠透過遍歷所有值來列印陣列中的每一項,但無法在 MongoDB 中獲取特定項
若要獲取特定元素,請使用 forEach() 進行迭代。讓我們使用文件建立一個集合 −
> db.demo742.insertOne({ "userDetails": [ { "userName":"Robert", "CountryName":"UK" }, { "userName":"David", "CountryName":"AUS" } ]} );
{
"acknowledged" : true,
"insertedId" : ObjectId("5ead790b57bb72a10bcf0677")
}使用 find() 方法顯示集合中的所有文件 −
> db.demo742.find().pretty();
這將生成以下輸出 −
{
"_id" : ObjectId("5ead790b57bb72a10bcf0677"),
"userDetails" : [
{
"userName" : "Robert",
"CountryName" : "UK"
},
{
"userName" : "David",
"CountryName" : "AUS"
}
]
}以下是從陣列中獲取元素的查詢 −
> var ListOfCountryName= {};
> db.demo742.find({}).forEach(function(doc) {
... doc.userDetails.forEach(function (d){
... ListOfCountryName[d.CountryName] =d.CountryName;
... });
... }
... )
> printjson(ListOfCountryName);這將生成以下輸出 −
{ "UK" : "UK", "AUS" : "AUS" }
廣告
資料結構
網路
關係型資料庫管理系統
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP