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

Použití $push v rámci Array v mongoose

To, na co míříte, není platná struktura. Místo toho pravděpodobně budete chtít schéma kde NetworkList přímo obsahuje pole ObjectId přátel uživatele:

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

Vaše dokumenty by pak vypadaly takto:

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

Poté můžete přidat nového přítele do NetworkList pomocí $push operátor takto:

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. Jak vytvořit DB pro kontejner MongoDB při spuštění?

  2. mongodb cluster s koncovým bodem ELB jako dns

  3. Jaký je smysl REDIS v zásobníku ELK?

  4. Jak pošlu objekt z MongoDB do nefritu?