sql >> Database teknologi >  >> NoSQL >> MongoDB

Mongoose dokumentreferencer med et en-til-mange forhold

Se befolkning, her uddrag et eksempel fra 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);

Altså eksemplet om Story modelbutikker relaterede Person._id i Story._creator . Når du finder et dokument med Story , kan du bruge populate() metode til at definere hvilken attribut i Person model, du vil hente på samme tid, såsom:

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

Jeg tror, ​​det er det, du leder efter. Eller også kan du bruge indlejrede samlinger i stedet for.



  1. Rækkefølgen af ​​svar på MongoDB $i forespørgsel?

  2. findOne Subdocument in Mongoose

  3. Kan ikke starte/starte lokal mongo db

  4. Opdatering af et stort antal poster i en samling