Delen via


update

De update opdracht wordt gebruikt om bestaande documenten in een verzameling te wijzigen. De update opdracht kan worden gebruikt om een of meer documenten bij te werken op basis van filtercriteria. Waarden van velden kunnen worden gewijzigd, nieuwe velden en waarden kunnen worden toegevoegd en bestaande velden kunnen worden verwijderd.

Voorbeeld(en)

Bekijk dit voorbeelddocument uit de archiefverzameling in de StoreData-database.

{
    "_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4",
    "name": "First Up Consultants | Beverage Shop - Satterfieldmouth",
    "location": {
        "lat": -89.2384,
        "lon": -46.4012
    },
    "staff": {
        "totalStaff": {
            "fullTime": 8,
            "partTime": 20
        }
    },
    "sales": {
        "totalSales": 75670,
        "salesByCategory": [
            {
                "categoryName": "Wine Accessories",
                "totalSales": 34440
            },
            {
                "categoryName": "Bitters",
                "totalSales": 39496
            },
            {
                "categoryName": "Rum",
                "totalSales": 1734
            }
        ]
    },
    "promotionEvents": [
        {
            "eventName": "Unbeatable Bargain Bash",
            "promotionalDates": {
                "startDate": {
                    "Year": 2024,
                    "Month": 6,
                    "Day": 23
                },
                "endDate": {
                    "Year": 2024,
                    "Month": 7,
                    "Day": 2
                }
            },
            "discounts": [
                {
                    "categoryName": "Whiskey",
                    "discountPercentage": 7
                },
                {
                    "categoryName": "Bitters",
                    "discountPercentage": 15
                },
                {
                    "categoryName": "Brandy",
                    "discountPercentage": 8
                },
                {
                    "categoryName": "Sports Drinks",
                    "discountPercentage": 22
                },
                {
                    "categoryName": "Vodka",
                    "discountPercentage": 19
                }
            ]
        },
        {
            "eventName": "Steal of a Deal Days",
            "promotionalDates": {
                "startDate": {
                    "Year": 2024,
                    "Month": 9,
                    "Day": 21
                },
                "endDate": {
                    "Year": 2024,
                    "Month": 9,
                    "Day": 29
                }
            },
            "discounts": [
                {
                    "categoryName": "Organic Wine",
                    "discountPercentage": 19
                },
                {
                    "categoryName": "White Wine",
                    "discountPercentage": 20
                },
                {
                    "categoryName": "Sparkling Wine",
                    "discountPercentage": 19
                },
                {
                    "categoryName": "Whiskey",
                    "discountPercentage": 17
                },
                {
                    "categoryName": "Vodka",
                    "discountPercentage": 23
                }
            ]
        }
    ]
}

Voorbeeld 1: Één document bijwerken met behulp van de operator $inc

De totale verkoop met 10 verhogen en het aantal fulltime personeel voor een document verlagen met de opgegeven _id.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$inc": {"sales.salesByCategory.0.totalSales": 10, "staff.totalStaff.fullTime": -6}})

Voorbeeld 2: Één document bijwerken met behulp van de operator $min

Werk het totaalaantal medewerkers voor het document bij met de opgegeven _id tot 10 als de huidige waarde van het veld groter is dan 10.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$min": {"staff.totalStaff.fullTime": 10}})

Voorbeeld 3: Één document bijwerken met behulp van de operator $max

Werk het totaalaantal medewerkers voor het document bij met de opgegeven _id tot 14 als de huidige waarde van het veld kleiner is dan 14.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$max": {"staff.totalStaff.fullTime": 14}})

Voorbeeld 4: Één document bijwerken met behulp van de operator $mul

Het aantal parttimemedewerkers met 2 voor het document vermenigvuldigen met de opgegeven _id waarde.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$mul": {"staff.totalStaff.partTime": 2}})

Voorbeeld 5: Één document bijwerken met behulp van de operator $rename

Wijzig de naam van de velden totalSales en totalStaff in respectievelijk fullSales en staffCounts.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$rename": {"sales.totalSales": "sales.fullSales", "staff.totalStaff": "staff.staffCounts"}})

Voorbeeld 6: Één document bijwerken met behulp van de operator $set

Stel het veld fullSales in op 3700 voor het document met de opgegeven _id waarde.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$set": {"sales.fullSales": 3700}})

Voorbeeld 7: Één document bijwerken met behulp van de operator $unset

Verwijder het lon-veld uit het locatieobject in het document met de opgegeven _id waarde.

db.stores.updateOne({"_id": "0fcc0bf0-ed18-4ab8-b558-9848e18058f4"}, {"$unset": {"location.lon": ""}})

Voorbeeld 8: meerdere documenten bijwerken

Werk alle documenten bij waarin het eerste promotieevenement in februari begint om te beginnen in maart.

db.stores.updateMany({"promotionEvents.0.promotionalDates.startDate.Month": 2}, {"$inc": {"promotionEvents.0.promotionalDates.startDate.Month": 1}})

Voorbeeld 9: Upsert één document

Stel de upsert-vlag in op True om een nieuw document te maken als het document dat is opgegeven in het queryfilter niet bestaat in de verzameling.

db.stores.updateOne({"_id": "NonExistentDocId"}, {"$set": {"name": "Lakeshore Retail", "sales.totalSales": 0}}, {"upsert": true})