& Ldquo; Комментарии & Rdquo; массив, возвращающий только идентификаторы комментариев [duplicate]

49
задан chovy 23 October 2012 в 21:09
поделиться

4 ответа

Чтобы заполнить ссылочные субдокументы, вам необходимо явно определить коллекцию документов, к которой ссылается идентификатор (например, created_by: { type: Schema.Types.ObjectId, ref: 'User' }).

Учитывая, что эта ссылка определена, а ваша схема в противном случае четко определена а также вы можете просто вызвать populate как обычно (например, populate('comments.created_by'))

Доказательство кода концепции:

// 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);
});

Наконец, обратите внимание, что populate работает только для так что вам нужно сначала передать свой элемент в запрос, а затем называть его:

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)
        });
    });
});
63
ответ дан andyvn22 3 September 2018 в 18:01
поделиться

@ user1417684 и @ chris-foster правы!

выдержка из рабочего кода (без обработки ошибок):

var SubItemModel = mongoose.model('subitems', SubItemSchema);
var ItemModel    = mongoose.model('items', ItemSchema);

var new_sub_item_model = new SubItemModel(new_sub_item_plain);
new_sub_item_model.save(function (error, new_sub_item) {

  var new_item = new ItemModel(new_item);
  new_item.subitem = new_sub_item._id;
  new_item.save(function (error, new_item) {
    // so this is a valid way to populate via the Model
    // as documented in comments above (here @stack overflow):
    ItemModel.populate(new_item, { path: 'subitem', model: 'subitems' }, function(error, new_item) {
      callback(new_item.toObject());
    });
    // or populate directly on the result object
    new_item.populate('subitem', function(error, new_item) {
      callback(new_item.toObject());
    });
  });

});
5
ответ дан chhtm 3 September 2018 в 18:01
поделиться

Я столкнулся с той же проблемой, но после нескольких часов усилий я нашел решение. Это может быть без использования внешнего плагина:)

applicantListToExport: function (query, callback) {
  this
   .find(query).select({'advtId': 0})
   .populate({
      path: 'influId',
      model: 'influencer',
      select: { '_id': 1,'user':1},
      populate: {
        path: 'userid',
        model: 'User'
      }
   })
 .populate('campaignId',{'campaignTitle':1})
 .exec(callback);
}
1
ответ дан Software Services 3 September 2018 в 18:01
поделиться

Это могло измениться с момента написания первоначального ответа, но похоже, что теперь вы можете использовать функцию Populate Models, чтобы не выполнить лишний findOne. См. http://mongoosejs.com/docs/api.html#model_Model.populate . Вы хотите использовать это внутри обработчика сохранения, как и findOne.

41
ответ дан user1417684 3 September 2018 в 18:01
поделиться
Другие вопросы по тегам:

Похожие вопросы: