MongoDB
 sql >> база данни >  >> NoSQL >> MongoDB

Mongodb и Express

http://mongoosejs.com/docs/populate.html уточнява с много хубав пример. Извлякох същността тук за вас

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

}

така че вече имате два модела история и човек, където историята препраща към човек чрез полето _creator.

сега, за да попълните _creator, докато правите заявки чрез история, вие правите следното:

{

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

но също така трябва да се уверите, че сте запазили записите правилно, за да ги извлечете правилно. докато записвате, просто трябва да присвоите _id. вижте по-долу.

{
var aaron = new Person({ _id: 0, name: 'Aaron', age: 100 });

aaron.save(function (err) {
  if (err) return handleError(err);

  var story1 = new Story({
    title: "Once upon a timex.",
    _creator: aaron._id    // assign the _id from the person
  });

  story1.save(function (err) {
    if (err) return handleError(err);
    // thats it!
  });
});

}



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. Функцията на javascript от страната на сървъра има ли проблеми с производителността в mongoDB?

  2. Как да постигнете връзка само за четене с помощта на pymongo

  3. Mongoose създава връзка за поддръжка на множество наематели в node.js

  4. Node.js + mongoose find замразява възел, когато има повече от 100 резултата

  5. MongooseJS - Как да запазите документ и препратен документ