sql >> Databasteknik >  >> NoSQL >> MongoDB

Mongoose dokumentreferenser med en en-till-många-relation

Se population, här extrahera ett exempel från 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);

Så exemplet om Story modellbutiker relaterade Person._id i Story._creator . När du hittar ett dokument med Story , kan du använda populate() metod för att definiera vilket attribut i Person modell du vill hämta samtidigt, till exempel:

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

Jag tror att det är detta du letar efter. Annars kan du använda kapslade samlingar istället.



  1. Hur kör man MongoDB native query (JSON) med endast mongo-java-drivrutin?

  2. Få bara ett specificerat fält i MongoDB med C#

  3. Manuell tillförsel av argument till en MongoDB-fråga för att stödja sorteringsfunktionen (för skiftlägesokänsligt index)

  4. Redis + ActionController::Live-trådar dör inte