0

我可以在这里使用一些帮助,我无法弄清楚为什么填充方法不能按预期工作。我想模拟一些里面有人的“房间”。

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") 
}

和一个包含一个条目的 Room 集合:

{ 
"_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: []
}

为什么猫鼬不填充人员字段?我只是不明白可能出了什么问题。

4

2 回答 2

2

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

于 2012-05-02T15:23:49.960 回答
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 || {}}

这应该让你走上正确的轨道:)

于 2012-04-30T12:05:15.563 回答