如何在快速

时间:2016-12-13 14:37:18

标签: node.js mongodb mongoose mongoose-schema mongoose-populate

我正在尝试构建多对多关系模式,并尝试构建虚拟访问相同的模式。最后在查询时尝试获取嵌入对象。我的架构看起来像下面的

//Mongoose Schema
var item1 = new Schema ({
  _id: Number,
  Item2Id: [{type: Number, ref: item2}],
  Detail1: String,
  Detail2: String
  ...
},{toObject:{virtuals:true},toJSON:{virtuals:true}});

var item2 = new Schema ({
  _id: Number,
  Item1Id: [{type: Number, ref: item1}],
  Detail1: String,
  Detail2: String
  ...
},{toObject:{virtuals:true},toJSON:{virtuals:true}});

item1.virtual('Item2Details').get(function() {
  var ids = this.Item2Id;
      details = [];
  ids.forEach(function(id, idx, array) {
    item2.findOne({'_id': id}).exec(function (err, doc) {
      details.push(doc);
      if(idx === array.length - 1)
        return details;
    });
  });
});

//app.js
app.get('/item1/:id', function(req, res){
  item1.findOne({'_id':req.params.id}).exec(function(err, doc){
    res.send(doc);
  });
});

我的期望是如果item1

{
  _id:1,
  Item2Id: [2, 3],
  Detail1: 'abc',
  Detail2: 'xyz'
}

和item2

{
  _id:2,
  Item2Id: [1],
  Detail1: 'abc',
  Detail2: 'xyz'
}
{
  _id:3,
  Item2Id: [1],
  Detail1: 'abc',
  Detail2: 'xyz'
}

结果响应应

{
  _id:1,
  Item2Id: [2,3],
  Item2Details: [
   {_id:2,
    Item2Id: [1],
    Detail1: 'abc',
    Detail2: 'xyz'},
  {_id:3,
    Item2Id: [1],
    Detail1: 'abc',
    Detail2: 'xyz'}],
  Detail1: 'abc',
  Detail2: 'xyz'
}

然而,我无法得到同样的结果。我试过,使用res.send(doc.Item2Details)并没有运气。也尝试在查找查询中使用populate,它也失败了一些本地和外来错误。假设它指的是以不同的方式定义虚拟(http://mongoosejs.com/docs/populate.html),即使我尝试使用以下链接也不起作用。

ref: 'item2',
localField: '_id',
foreignField: 'Item2Id'

向正确方向欣赏任何指针。

0 个答案:

没有答案