首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从MongoDB检索子文档时出现问题

从MongoDB检索子文档时出现问题
EN

Stack Overflow用户
提问于 2017-07-13 06:49:53
回答 1查看 25关注 0票数 1

我有以下数据集:

代码语言:javascript
复制
{
    "_id" : ObjectId("59668a22734d1d48cf34de08"),
    "name" : "Nobody Cares",
    "menus" : [ 
        {
            "_id" : "menu_123",
            "name" : "Weekend Menu",
            "description" : "A menu for the weekend",
            "groups" : [ 
                {
                    "name" : "Spirits",
                    "has_mixers" : true,
                    "sizes" : [ 
                        "Single", 
                        "Double"
                    ],
                    "categories" : [ 
                        {
                            "name" : "Vodka",
                            "description" : "Maybe not necessary?",
                            "drinks" : [ 
                                {
                                    "_id" : "drink_123",
                                    "name" : "Absolut",
                                    "description" : "Fancy ass vodka",
                                    "sizes" : [ 
                                        {
                                            "_id" : "size_123",
                                            "size" : "Single",
                                            "price" : 300
                                        }
                                    ]
                                }
                            ]
                        }
                    ]
                }
            ],
            "mixers" : [ 
                {
                    "_id" : "mixer_1",
                    "name" : "Coca Cola",
                    "price" : 150
                }, 
                {
                    "_id" : "mixer_2",
                    "name" : "Lemonade",
                    "price" : 120
                }
            ]
        }
    ]
}

我尝试从该数据集中检索一杯饮料,我使用以下聚合查询:

代码语言:javascript
复制
db.getCollection('places').aggregate([
    { $match : {"menus.groups.categories.drinks._id" : "drink_123"} },
    { $unwind: "$menus" },
    { $project: { "_id": 1, "menus": { "groups": { "categories": { "drinks": { "name": 1 } } } }  } }
])

但是,它返回的是数据集的完整结构以及正确的数据。

因此,不是:

代码语言:javascript
复制
{
  "_id": "drink_123",
  "name": "Absolut"
}

我得到了:

代码语言:javascript
复制
{
  "_id": ObjectId("59668a22734d1d48cf34de08"),
  "menus": {
    "groups": {
      "categories": {
        "drinks": { "name": "Absolut" } 
      }
    }
  }
}

例如。有什么想法可以只检索子文档吗?

EN

回答 1

Stack Overflow用户

发布于 2017-07-13 14:48:27

如果您需要保留深度嵌套的模型,则此调用将产生所需的输出:

代码语言:javascript
复制
db.getCollection('places').aggregate([
    { $match : {"menus.groups.categories.drinks._id" : "drink_123"} },
    { $project: {"_id": '$menus.groups.categories.drinks._id', name: '$menus.groups.categories.drinks.name'}},
    { $unwind: "$name" },
    { $unwind: "$name" },
    { $unwind: "$name" },
    { $unwind: "$name" },
    { $unwind: "$_id" },
    { $unwind: "$_id" },
    { $unwind: "$_id" },
    { $unwind: "$_id" }
])

大量展开是drinks子文档深度嵌套的结果。

然而,FWIW,这种类型的查询可能确实表明该模型不是“读取友好的”。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45068723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档