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

Jak vytvořit schéma Mongoose s polem ID objektů?

Pokud chcete použít funkci Mongoose naplnit, měli byste udělat:

var userSchema = mongoose.Schema({
  email: { type: String, required: true, unique: true},
  password: { type: String, required: true},
  name: {
      first: { type: String, required: true, trim: true},
      last: { type: String, required: true, trim: true}
  },
  phone: Number,
  lists: [listSchema],
  friends: [{ type : ObjectId, ref: 'User' }],
  accessToken: { type: String } // Used for Remember Me
});
exports.User = mongoose.model('User', userSchema);

Tímto způsobem můžete provést tento dotaz:

var User = schemas.User;
User
 .find()
 .populate('friends')
 .exec(...)

Uvidíte, že každý uživatel bude mít řadu uživatelů (přátel tohoto uživatele).

A správný způsob vkládání je, jak řekl Gabor:

user.friends.push(newFriend._id);


  1. Mongo třídí podle vypočítané podmínky

  2. Přehled databáze MongoDB Profiler

  3. Jaký je nejjednodušší způsob, jak najít největší objekty v Redis?

  4. Mongo jak $lookup s DBRef