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

jak mohu přepsat svůj dotaz na mongoose po rozdělení dat z jednoho modelu na dva?

Nejprve vám navrhuji, abyste použili dotaz na vyplnění, pokud máte pocit, že vám tento dotaz neposkytne data, která potřebujete, můžete spustit dva dotazy a tyto výsledky sloučit.

pro populace jsem našel řešení z oficiálního dokumentu mongoose. můžete to udělat takto.

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

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

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

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

Story
.findOne({ title: 'Once upon a timex.' })
.populate('_creator')
.exec(function (err, story) {
  if (err) return handleError(err);
  console.log('The creator is %s', story._creator.name);
  // prints "The creator is Aaron"
});

zde je odkaz na dokument:http://mongoosejs.com/docs/populate.html




  1. Redis - Ruční povýšení podřízeného na master

  2. nastavte výchozí hodnoty na pole mongoose v node js

  3. MongoDB – kolekce postrádá jedinečný index na _id

  4. Možnosti Spring Data-MongoDb pro metodu agregace