sql >> Database teknologi >  >> NoSQL >> MongoDB

Brug af $push i Array i mongoose

Det, du sigter efter, er ikke en gyldig struktur. Det, du sandsynligvis vil have i stedet, er et skema, hvor NetworkList indeholder direkte en række ObjectId'er for brugerens venner:

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

Dine dokumenter vil så se sådan ud:

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

Derefter kan du tilføje en ny ven til NetworkList ved at bruge $push operatør som denne:

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. Brug af S3 som en database vs. database (f.eks. MongoDB)

  2. Forespørg MongoDB for flere ObjectID'er i Array

  3. Laravel Caching med Redis er meget langsom

  4. Sammenlign to objektarrays og kontroller, om de har fælles elementer