43

I've got a schema that looks a bit like:

var conversationSchema = new Schema({
    created: { type: Date, default: Date.now },
    updated: { type: Date, default: Date.now },
    recipients: { type: [Schema.ObjectId], ref: 'User' },
    messages: [ conversationMessageSchema ]
});

So my recipients collection, is a collection of object id's referencing my user schema / collection.

I need to populate these on query, so i'm trying this:

Conversation.findOne({ _id: myConversationId})
.populate('user')
.run(function(err, conversation){
    //do stuff
});

But obviously 'user' isn't populating...

Is there a way I can do this?

Alex
  • 37,502
  • 51
  • 204
  • 332

2 Answers2

123

For anyone else coming across this question.. the OP's code has an error in the schema definition.. it should be:

var conversationSchema = new Schema({
    created: { type: Date, default: Date.now },
    updated: { type: Date, default: Date.now },
    recipients: [{ type: Schema.ObjectId, ref: 'User' }],
    messages: [ conversationMessageSchema ]
});
mongoose.model('Conversation', conversationSchema);
jackdbernier
  • 1,542
  • 1
  • 17
  • 32
Duncan_m
  • 2,526
  • 2
  • 21
  • 19
43

Use the name of the schema path instead of the collection name:

Conversation.findOne({ _id: myConversationId})
.populate('recipients') // <==
.exec(function(err, conversation){
    //do stuff
});
aaronheckmann
  • 10,625
  • 2
  • 40
  • 30