MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

Wkładka Mongodb/mongoose nie jest funkcją

Sprawdź ten przykład kodu, powinien działać tak, jak potrzebujesz.

Widzę tutaj każdą niezrozumiałą część.

Zadawaj pytania w komentarzach, mogę wyjaśnić, jeśli nie rozumiem.

var tokenSchema = mongoose.Schema({
  owner: { 
    type: 'String',
    required: true,
    index: {
      unique: true
    }
  }, 
  token: {
    type: ['String'],
    default: []
  }
});

var Token = module.exports = mongoose.model('tokens', tokenSchema);

//save token, if token document exist so push it in token array and save
module.exports.saveToken = function(owner_id, token, callback){
    Token
      .findOne({owner: owner_id})
      .exec(function(err, tokenDocument) {
        if(tokenDocument) {
          if(tokenDocument.token.indexOf(token) > -1) { // found that token already exist in document token array
            return callback(null, tokenDocument); // don't do anything and return to callback existing tokenDocument
          }

          tokenDocument.token.push(token);
          tokenDocument.save(callback);
          return; // don't go down, cuz we already have a token document
        }

        new Token({owner: owner_id, token: [token]}).save(callback); // create new token document with single token in token array
    });
}

//get all tokens by owner_id
module.exports.getAllTokens = function(owner_id, callback){
    Token
      .findOne({owner: owner_id})
      .exec(function(err, tokenDocument) {
        callback(err, tokenDocument.token);
      });
}


  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. związek wiele do wielu z nosql (mongodb i mangusta)

  2. Procent warunków OR dopasowanych w mongodb

  3. Białe znaki MongoDB

  4. meteor:jak mogę wykonać kopię zapasową mojej bazy danych mongo

  5. dodaj pola created_at i updated_at do schematów mangusty