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

Opdater mange, hvis der findes, ellers opret et nyt dokument for hvert LeadId, der ikke eksisterer

Fra din forespørgsel, da du laver .updateMany() , du behøver ikke at gøre { multi: true } . Alligevel normalt kan du gøre upsert ved hjælp af {upset: true} , men det ville ideelt set kun oprette et nyt dokument baseret på filterkriterier med opdateringsfelter fra inputforespørgsel, hvis der ikke findes noget match i DB. Men siden her har vi en liste ($in ) i filterkriterier virker det muligvis ikke normalt, prøv dette :

let winnerLeads = [1, 2, 3, 31, 5]
let groupTarget = 1
let howManyClaims = 2
let bulkArr = []
for (i of winnerLeads) {
    bulkArr.push({
        updateOne: {
            "filter": {
                LeadId: i,
                TargetedToBeClaimedByClientType: groupTarget
            },
            // If you wanted it to be incremented rather than replace the field, then try `$inc` instead of `$set`.
            "update": { $set: { TotalClaimsToBeClaimedByClientType: howManyClaims } },
            "upsert": true
        }
    })
}
db.EightWeekGamePlan.bulkWrite(bulkArr);

Samlingsdata :

/* 1 */
{
    "_id" : ObjectId("5e06eb8f400289966e00fac2"),
    "LeadId" : 1,
    "TotalClaimsToBeClaimedByClientType" : 1.0,
    "TargetedToBeClaimedByClientType" : 1
}

/* 2 */
{
    "_id" : ObjectId("5e06eb98400289966e00fb88"),
    "LeadId" : 2,
    "TotalClaimsToBeClaimedByClientType" : 1.0,
    "TargetedToBeClaimedByClientType" : 1
}

/* 3 */
{
    "_id" : ObjectId("5e06eba0400289966e00fc47"),
    "LeadId" : 3,
    "TotalClaimsToBeClaimedByClientType" : 0,
    "TargetedToBeClaimedByClientType" : 11
}

/* 4 */
{
    "_id" : ObjectId("5e06ebac400289966e00fd4b"),
    "LeadId" : 4,
    "TotalClaimsToBeClaimedByClientType" : 1,
    "TargetedToBeClaimedByClientType" : 11
}

/* 5 */
{
    "_id" : ObjectId("5e06ecef400289966e01273a"),
    "LeadId" : 5,
    "TotalClaimsToBeClaimedByClientType" : 1.0,
    "TargetedToBeClaimedByClientType" : 1
}

Resultat:

/* 1 */
{
    "_id" : ObjectId("5e06eb8f400289966e00fac2"),
    "LeadId" : 1,
    "TotalClaimsToBeClaimedByClientType" : 2.0,
    "TargetedToBeClaimedByClientType" : 1
}

/* 2 */
{
    "_id" : ObjectId("5e06eb98400289966e00fb88"),
    "LeadId" : 2,
    "TotalClaimsToBeClaimedByClientType" : 2.0,
    "TargetedToBeClaimedByClientType" : 1
}

/* 3 */
{
    "_id" : ObjectId("5e06eba0400289966e00fc47"),
    "LeadId" : 3,
    "TotalClaimsToBeClaimedByClientType" : 0,
    "TargetedToBeClaimedByClientType" : 11
}

/* 4 */
{
    "_id" : ObjectId("5e06ebac400289966e00fd4b"),
    "LeadId" : 4,
    "TotalClaimsToBeClaimedByClientType" : 1,
    "TargetedToBeClaimedByClientType" : 11
}

/* 5 */
{
    "_id" : ObjectId("5e06ecef400289966e01273a"),
    "LeadId" : 5,
    "TotalClaimsToBeClaimedByClientType" : 2,
    "TargetedToBeClaimedByClientType" : 1
}

/* 6 */
{
    "_id" : ObjectId("5e071eb1400289966e0597a0"),
    "TargetedToBeClaimedByClientType" : 1.0,
    "LeadId" : 3.0,
    "TotalClaimsToBeClaimedByClientType" : 2.0
}

/* 7 */
{
    "_id" : ObjectId("5e071e62400289966e059168"),
    "TargetedToBeClaimedByClientType" : 1.0,
    "LeadId" : 31.0,
    "TotalClaimsToBeClaimedByClientType" : 2.0
}

Grundlæggende returnerer bulkWrite ikke nogen dokumenter undtagen skriveresultat, du kan verificere i DB for opdateringsoperationsresultat, også fra ovenstående resultat 6 fik indsat som LeadId : 3 + TargetedToBeClaimedByClientType" : 1.0 (Så LeadId:3 er duplikeret) kombination er ikke til stede i DB og 7 blev indsat som LeadId : 31 er ikke til stede i DB, Resterende 1 ,2 ,5 's TotalClaimsToBeClaimedByClientType blev opdateret.

Ref : bulkWrite




  1. Mongoose ser ud til at fejle stille og roligt

  2. Bedste måde at gemme tidspunktet på dagen i Mongoose

  3. MongoDB 4.0 JREundtagelse:"Markør"-indstillingen er påkrævet, undtagen for aggregering med forklare-argumentet

  4. mongodb samlet forespørgsel returnerer ikke den rigtige sum ved brug af $sum