I tried lot of combination didnt work out so need your help.
Consider your have a document schema and versions
var VersionSchema = mongoose.createSchema("version", {
version: { type: Number},
metadata: { type: Schema.Types.ObjectId, ref: 'Metadata' }
});
var documentSchema = mongoose.createSchema("document", {
projectId: { type: Schema.Types.ObjectId},
versions: [VersionSchema],
deleted: { type: Boolean, default: false}
});
data will look like this
{
_id: a58107da0dc3da020998787c,
projectId: 09434766ab47c29609972596,
deleted: false,
versions: [
{ _id: 9ac67dc1b84df1ff09988ea1, version: 1, Metadata: [Object] },
{ _id: 9ac67dc1b84df1ff09988ea2, version: 2, Metadata: [Object] }
]
}
I want to populate only latest version document..say version 2..not all sub versions..
I tried this but need help..
Document.findOne({ projectId: projectId }, function(error, document) {
var options = [{
path: 'versions.Metadata,
model: Metadata
//,
//match: { version: 2 }
}];
Version.populate(document, options, function(err, doc) {
deferred.resolve(doc);
});
});