MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

So durchlaufen Sie verschachtelte Dokumente rekursiv in MongoDB

Der einfachste Weg, dies zu tun, ist die Verwendung von Bluebird-Promises, insbesondere each , props , reduce und map Methoden, abhängig von Ihrem Anwendungsfall.

In Ihrem Fall würde ich etwas in der Art von

vorschlagen
var bluebird = require('bluebird');
var mongoose = require('mongoose');
var UserModel = mongoose.model('User');

function getUser(userId) {
  return UserModel.findOne({_id: userId}).lean().exec()
    .then(function(user){
      return bluebird.props({
        firstName: user.firstName,
        parents: bluebird.map(user.parents, getUser),
        children: bluebird.map(user.children, getUser),
        partner: bluebird.map(user.partner, getUser),
        sibling: bluebird.map(user.sibling, getUser)
      })
    });
}

// Then call getUser once on the root node, e.g.
getUser(rootUserObjectId)
  .then(function(userTree){
    console.log(userTree)
  })

Lassen Sie mich wissen, wie das geht!