sql >> Databáze >  >> NoSQL >> MongoDB

Mongoose vložené dokumenty / DocumentsArrays id

Místo provádění push() s objektem json, jako je tento (způsob, jak navrhují mongoose docs):

// create a comment
post.comments.push({ title: 'My comment' });

Měli byste vytvořit skutečnou instanci vašeho vloženého objektu a push() že místo toho. Pak z něj můžete přímo uchopit pole _id, protože mongoose jej nastaví, když je objekt vytvořen. Zde je úplný příklad:

var mongoose = require('mongoose')
var Schema = mongoose.Schema
var ObjectId = Schema.ObjectId

mongoose.connect('mongodb://localhost/testjs');

var Comment = new Schema({
    title     : String
  , body      : String
  , date      : Date
});

var BlogPost = new Schema({
    author    : ObjectId
  , title     : String
  , body      : String
  , date      : Date
  , comments  : [Comment]
  , meta      : {
        votes : Number
      , favs  : Number
    }
});

mongoose.model('Comment', Comment);
mongoose.model('BlogPost', BlogPost);

var BlogPost = mongoose.model('BlogPost');
var CommentModel = mongoose.model('Comment')


var post = new BlogPost();

// create a comment
var mycomment = new CommentModel();
mycomment.title = "blah"
console.log(mycomment._id) // <<<< This is what you're looking for

post.comments.push(mycomment);

post.save(function (err) {
  if (!err) console.log('Success!');
})



  1. MongoDB získá maximální datum uvnitř dvojitě vnořeného pole

  2. Naplánujte úlohu Node.js každých pět minut

  3. Získání náhodných záznamů a zobrazení v konkrétním formátu pomocí PHP a MongoDB

  4. Součet ve vnořeném dokumentu MongoDB