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

Używanie $push wewnątrz tablicy w manguście

To, do czego dążysz, nie jest prawidłową strukturą. Zamiast tego prawdopodobnie potrzebujesz schematu, w którym NetworkList bezpośrednio zawiera tablicę identyfikatorów ObjectId znajomych użytkownika:

var NetworkSchema = new Schema({
    UserID: {
        type: String,
        default: '',
        trim: true
    },
    NetworkList: [{
        type: Schema.ObjectId,
        ref: 'User'
    }]
});

Twoje dokumenty będą wtedy wyglądać tak:

{
    "_id" : ObjectId("548adbc8b7eac44013bf188d"),
    "NetworkList" : [ 
        ObjectId("5486fab40bc27314276be8cf") 
    ],
    "UserID" : "547eaaab6c39471c3f5aebb6",
    "__v" : 0
}

Następnie możesz dodać nowego przyjaciela do NetworkList za pomocą $push operator w ten sposób:

exports.update = function(req, res) {
    var query={'UserID': req.body.UserID};
    var update = {$push: {'NetworkList': req.body.FriendID}};

    Network.findOneAndUpdate(query, update, function(err, doc){ ... });
};



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB $dayOfYear

  2. Jakie są wady przechowywania Guid jako String w MongoDB?

  3. Jak znaleźć tylko jeden dokument z Restivus i Curl

  4. Emulacja transakcji CouchDB/Couchbase/MongoDB?

  5. allowDiskUse w ramach agregacji ze sterownikiem MongoDB C#