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

Reference dokumentu Mongoose se vztahem jedna k mnoha

Podívejte se na populaci, zde vytáhněte příklad z Mongoose.

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

var personSchema = Schema({
  _id     : Schema.Types.ObjectId,
  name    : String,
  age     : Number,
  stories : [{ type: Schema.Types.ObjectId, ref: 'Story' }]
});

var storySchema = Schema({
  _creator : { type: Schema.Types.ObjectId, ref: 'Person' },
  title    : String,
  fans     : [{ type: Schema.Types.ObjectId, ref: 'Person' }]
});

var Story  = mongoose.model('Story', storySchema);
var Person = mongoose.model('Person', personSchema);

Takže příklad o, Story model ukládá související Person._id v Story._creator . Když najdete dokument Story , můžete použít populate() metoda k definování atributu v Person model, který chcete ve stejnou dobu načíst, například:

Story.findOne({_id: 'xxxxxxx'}).populate('person', 'name age').exec(function(err, story) {
  console.log('Story title: ', story.title);
  console.log('Story creator', story.person.name);
});

Věřím, že to je to, co hledáte. Nebo můžete místo toho použít vnořené kolekce.



  1. Řetězec projektu agregace MongoDB na ObjectId

  2. Přihlaste se k odběru více kanálů se stejným vláknem Jedis

  3. MongoDB $project:Zachovat předchozí pole kanálu

  4. mongodb přidat čítač ke každému načtenému dokumentu