首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >在mongoose中填充嵌套数组

在mongoose中填充嵌套数组
EN

Stack Overflow用户
提问于 2013-10-07 18:32:14
回答 12查看 125.6K关注 0票数 147

如何在示例文档中填充“组件”:

代码语言:javascript
复制
  {
    "__v": 1,
    "_id": "5252875356f64d6d28000001",
    "pages": [
      {
        "__v": 1,
        "_id": "5252875a56f64d6d28000002",
        "page": {
          "components": [
            "525287a01877a68528000001"
          ]
        }
      }
    ],
    "author": "Book Author",
    "title": "Book Title"
  }

这是我的JS,我在这里得到Mongoose的文档:

代码语言:javascript
复制
  Project.findById(id).populate('pages').exec(function(err, project) {
    res.json(project);
  });
EN

回答 12

Stack Overflow用户

回答已采纳

发布于 2015-12-24 06:58:36

Mongoose 4.5支持此功能

代码语言:javascript
复制
Project.find(query)
  .populate({ 
     path: 'pages',
     populate: {
       path: 'components',
       model: 'Component'
     } 
  })
  .exec(function(err, docs) {});

并且您可以加入多个深层级别。

编辑2021年3月17日:这是库的实现,它在后台做的是进行另一个查询来为你获取东西,然后连接到内存中。虽然这项工作,但我们真的不应该依赖。它将使您的数据库设计看起来像SQL表。这是成本高昂的操作,并且不能很好地扩展。请尝试设计您的文档以减少联接。

票数 341
EN

Stack Overflow用户

发布于 2013-10-07 22:40:26

这对我来说很有效:

代码语言:javascript
复制
 Project.find(query)
  .lean()
  .populate({ path: 'pages' })
  .exec(function(err, docs) {

    var options = {
      path: 'pages.components',
      model: 'Component'
    };

    if (err) return res.json(500);
    Project.populate(docs, options, function (err, projects) {
      res.json(projects);
    });
  });

文档:Model.populate

票数 114
EN

Stack Overflow用户

发布于 2016-04-16 12:02:36

正如其他人所指出的,Mongoose 4支持这一点。需要注意的是,如果需要,您也可以进行更深层次的递归--尽管文档中没有注明:

代码语言:javascript
复制
Project.findOne({name: req.query.name})
    .populate({
        path: 'threads',
        populate: {
            path: 'messages', 
            model: 'Message',
            populate: {
                path: 'user',
                model: 'User'
            }
        }
    })
票数 47
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19222520

复制
相关文章

相似问题

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