在 MongoDB 4 中执行嵌套查询以提取特定文档


对于嵌套查询,我们首先使用文档创建集合 −

> db.demo492.insertOne({
...    "ProductDetails" :
...    {
...       "StockDetails" : [
...          { "ProductName" : "Product-1" },
...          {"ProductName" : "Product-2"},
...          { "ProductName" : "Product-3"}
...
...       ]
...
...    }
... });
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e849db8b0f3fa88e22790c2")
}
>
>
>
> db.demo492.insertOne({
...    "ProductDetails" :
...    {
...       "StockDetails" : [
...          { "ProductName" : "Product-4" },
...          {"ProductName" : "Product-5"},
...          { "ProductName" : "Product-6"}
...
...       ]
...
...    }
... });
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e849dceb0f3fa88e22790c3")
}

在集合中使用 find() 方法显示所有文档 −

> db.demo492.find();

这会生成以下输出 −

{ "_id" : ObjectId("5e849db8b0f3fa88e22790c2"), "ProductDetails" : { "StockDetails" : [ {
"ProductName" : "Product-1" }, { "ProductName" : "Product-2" }, { "ProductName" : "Product3" } ] } }
{ "_id" : ObjectId("5e849dceb0f3fa88e22790c3"), "ProductDetails" : { "StockDetails" : [ {
"ProductName" : "Product-4" }, { "ProductName" : "Product-5" }, { "ProductName" : "Product6" } ] } }

以下是使用点表示法在 MongoDB 中显示嵌套查询以提取特定文档 −

> db.demo492.find({ "ProductDetails.StockDetails.ProductName":"Product-1"});

这会生成以下输出 −

{ "_id" : ObjectId("5e849db8b0f3fa88e22790c2"), "ProductDetails" : { "StockDetails" : [ {
"ProductName" : "Product-1" }, { "ProductName" : "Product-2" }, { "ProductName" : "Product3" } ] } }

更新于:13-5-2020

409 个视图

开启您 职业生涯

完成课程后获得认证

开始入门
广告