使用mongoose在MongoDB中创建记录时填充数组

时间:2013-08-05 02:39:53

标签: javascript mongodb express mongoose

我正在编写一个跟踪成员及其认证的应用程序。每个成员都有一些引用其他模型的数组,如Mongoose population docs中所述。

Member架构

{
  name: {
    first: String,
    last: String
  },
  unit: Number,

  // more stuff

  class_year: Number,
  campus_box: String,
  campus_address: String,

  // more stuff

  emails: [{ type: mongoose.Schema.Types.ObjectId, ref: 'Email' }],
  certifications: [{ type: mongoose.Schema.Types.ObjectId, ref: 'Certification' }],
  service_credits: [{ type: mongoose.Schema.Types.ObjectId, ref: 'ServiceCredit' }]
}

Certification架构

{
  type: String,
  issue: Date,
  expiry: Date,
  number: String,
  _member: { type: mongoose.Schema.Types.ObjectId, ref: 'Member' }
}

EmailServiceCredit的架构相似,因为它们都有_member字段。

当我创建Email时,会将其添加到Email模型中,然后我可以执行

var Email = mongoose.model('Email');
Email.findOne().populate('_member').exec(function (err, email) {
  console.log(email._member.name.first);
});

但是,它没有添加到Member模式中的数组中,因为当我运行

var Member = mongoose.model('Member');
Member.findOne().populate('emails').exec(function (err, member) {
  res.json(200, member);
});

我在JSON中获得emails: [],当明显与该成员关联Email时。

我已经阅读了Mongoose API,需要填充文档本身,因此我尝试使用以下内容执行http://mongoosejs.com/docs/api.html#document_Document-populate中引用的内容:

var Member = mongoose.model('Member');
Member.findOne({ _id: req.session.member._id }, function (err, member) {
  member.populate('emails', function (err) {
    console.log('populated emails');
  });
});

但我收到错误:(member's JSON data) has no method 'populate'。我知道我试图在错误的事情上运行populate,但我无法弄清楚正确的方法是什么。

1 个答案:

答案 0 :(得分:0)

我也遇到了填充数组的问题,你定义的模式将为每个数组元素创建一个子文档(尝试转储数组)。

尝试将架构更改为:

emails: [ type: mongoose.Schema.Types.ObjectId ]

并使用

Member.findOne().populate({ path: 'emails', model: 'Email' }).exec(function (err, member) {
    res.json(200, member);
});

填充数组。