0

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);
    });
});
laggingreflex
  • 32,948
  • 35
  • 141
  • 196
procoder
  • 31
  • 1
  • 7

1 Answers1

0
Document.findOne({ projectId: projectId }, function(error, document) {
    var options = [{
                    path: 'versions.Metadata,
                    model: Metadata
                   }];
    var version = document.versions[document.versions.length - 1];
    Version.populate(version, options, function(err, updatedVer) {
         deferred.resolve(updatedVer);
        });
  });
procoder
  • 31
  • 1
  • 7