Mongoose:populate方法不能正常工作

时间:2012-04-30 10:20:31

标签: node.js mongodb mongoose

我可以在这里使用一些帮助,我无法弄清楚为什么populate方法不能按预期工作。 我想为他们内部的人建模一些“房间”。

var PersonSchema = new Schema({
    _id   : Schema.ObjectId,
    name  : String,
});
var Person = mongoose.model('Person', PersonSchema, 'Person');

var RoomSchema = new Schema({
      _id    : Schema.ObjectId, 
      name : String,
      People : [{ type: Schema.ObjectId, ref: 'Person' }],
});
var Room = mongoose.model('Room', RoomSchema, 'Room');

所以,我有一个带有一个条目的Person集合:

{ 
"name" : "person1", 
"_id" : ObjectId("4f9e5bb68bcd69fb0c000002") 
}

和一个带有一个条目的房间集合:

{ 
"_id" : ObjectId("4f9e5bb68bcd69fb0c000001"), 
"name" : "room1", 
"People" : [ ObjectId("4f9e5bb68bcd69fb0c000002") ] 
}

当我尝试执行此查询时:

Room.findOne({ 'name': 'room1' }).populate('People').run(function (err, result) {
  if(err) console.log(err);
  console.log(result);
});

我得到了输出:

{ _id: 4f9e5bb68bcd69fb0c000001,
  name: 'room1',
  People: []
}

为什么Mongoose不填充人民领域?我只是不明白可能出现的问题。

2 个答案:

答案 0 :(得分:2)

此问题是2.x版本的mongoose中的一个错误。它已修复:https://github.com/LearnBoost/mongoose/issues/877

答案 1 :(得分:1)

因为猫鼬没有'加入'数据(这是我认为你想要做的)。

你想做的是这样的事情(注意这是评论和博客)

Schema

var Comments = new Schema({
    title     : String
  , body      : String
  , date      : Date
});

var BlogPost = new Schema({
    author    : ObjectId
  , title     : String
  , body      : String
  , buf       : Buffer
  , date      : Date
  , comments  : [Comments]
  , meta      : {
      votes : Number
    , favs  : Number
  }
});

然后创建博客模型并设置评论(示例中的房间中的人员)

// retrieve my model
var BlogPost = mongoose.model('BlogPost');

// create a blog post
var post = new BlogPost();

// create a comment
post.comments.push({ title: 'My comment' });

post.save(function (err) {
  if (!err) console.log('Success!');
});

如果您不想执行嵌入式文档,可以从该回调中进行搜索。例如,这是我的咖啡脚本示例,正是从推文作者那里获取用户名:

ModelTweets.find {}, (err, tweetResults) ->
    if tweetResults.length == 0
      res.render 'tweets/index', tweets: 0
    else
      # Get the Author for each tweet
      tweetResults.forEach (tweetInfo) ->
        count++
        ModelUser.findOne {'_id': tweetInfo.author}, (err, userInfo) ->
          tweets.push {id: tweetInfo._id, tweet: tweetInfo.tweet, created_at: tweetInfo.created_at, author: userInfo.username}

        if count == tweetResults.length
          res.render 'tweets/index', {tweets: tweets || {}}

这应该让你走上正轨:)