sql >> Database >  >> NoSQL >> MongoDB

Meerdere push-naar-geneste arrays maken

Probleem:in arrayfilters komt de _id overeen met een tekenreeks in plaats van ObjectId

De volgende zoekopdracht zou de verzameling precies bijwerken:

db.companies.update(
    {
        _id: ObjectId("5d7052a3807ab14e286ba5bd")
    }, 
    {
        $push: {
            "companyBases.$[filter1].vehicles": {
                "name": "Truck 1",
                "combustion": 28
            },
            "companyBases.$[filter2].vehicles": {
                "name": "Truck 2",
                "combustion": 28
            }
        }
    }, 
    {
        "arrayFilters": [{
                "filter1._id": ObjectId("5d7052a3807ab14e286ba5b0")
            },
            {
                "filter2._id": ObjectId("5d7052a3807ab14e286ba5af")
            }
        ]
    }
)



  1. MongoDB $ voorbeeld

  2. Push waarde naar Array als sleutel niet bestaat Mongoose

  3. Syntaxisfout Onverwachte token ILLEGAL Mongo Console

  4. Meteor en DBrefs