39

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
  • 35,969
  • 49
  • 197
  • 322

2 Answers2

119

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,482
  • 1
  • 17
  • 31
Duncan_m
  • 2,477
  • 2
  • 20
  • 19
39

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,205
  • 2
  • 38
  • 30