MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Jak wypełnić dokument podrzędny w manguście po jego utworzeniu?

W celu wypełnienia poddokumentów, do których istnieją odniesienia, należy jawnie zdefiniować kolekcję dokumentów, do której odwołuje się identyfikator (np. created_by: { type: Schema.Types.ObjectId, ref: 'User' } ).

Biorąc pod uwagę, że to odniesienie jest zdefiniowane, a Twój schemat jest również dobrze zdefiniowany, możesz teraz po prostu wywołać populate jak zwykle (np. populate('comments.created_by') )

Kod dowodu koncepcji:

// Schema
var mongoose = require('mongoose');
var Schema = mongoose.Schema;

var UserSchema = new Schema({
  name: String
});

var CommentSchema = new Schema({
  text: String,
  created_by: { type: Schema.Types.ObjectId, ref: 'User' }
});

var ItemSchema = new Schema({
   comments: [CommentSchema]
});

// Connect to DB and instantiate models    
var db = mongoose.connect('enter your database here');
var User = db.model('User', UserSchema);
var Comment = db.model('Comment', CommentSchema);
var Item = db.model('Item', ItemSchema);

// Find and populate
Item.find({}).populate('comments.created_by').exec(function(err, items) {
    console.log(items[0].comments[0].created_by.name);
});

Na koniec zauważ, że populate działa tylko dla zapytań, więc musisz najpierw przekazać swój element do zapytania, a następnie wywołać go:

item.save(function(err, item) {
    Item.findOne(item).populate('comments.created_by').exec(function (err, item) {
        res.json({
            status: 'success',
            message: "You have commented on this item",
            comment: item.comments.id(comment._id)
        });
    });
});


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. kopia mongo z jednej kolekcji do drugiej (na tej samej bazie danych)

  2. loguj w aplikacji wszystkie zapytania odpalane przez mangusty

  3. $rtrim . MongoDB

  4. Elasticsearch vs. MongoDB do aplikacji filtrującej

  5. Czy MongoDB ponownie wykorzystuje usunięte miejsce?