Hey,
I’ve been trying to modify a value in multiple arrays for a few arrays and I can’t find documentation on how to do this.
My collection looks like this
"rates": [
{
"category": "Web",
"seniorityRates": [
{
"seniority": "junior",
"rate": 100
},
{
"seniority": "intermediate",
"rate": 135
},
{
"seniority": "senior",
"rate": 165
}
]
}
]
I’m just trying to modify “junior” to “beginner”, this should be simple.
Thanks to these answers:
https://stackoverflow.com/questions/54055702/how-can-i-update-a-multi-level-nested-array-in-mongodb
https://stackoverflow.com/questions/9611833/mongodb-updating-fields-in-nested-array
I’ve manage to write that python code (pymongo), but it doesn’t works…
result = my_coll.update_many({},
{
"$set":
{
"rates.$[].seniorityRates.$[j].seniority" : new
}
},
upsert=False,
array_filters= [
{
"j.seniority": old
}
]
)
The path ‘rates’ must exist in the document in order to apply array updates.
It correspond to this command that doesn’t work either
db.projects.updateMany({},
{
$set:
{
"rates.$[].seniorityRates.$[j].seniority" : "debutant"
}
},
{ arrayFilters = [
{
"j.seniority": "junior"
}
]
}
)
clone(t={}){const r=t.loc||{};return e({loc:new Position("line"in r?r.line:this.loc.line,"column"in r?r.column:……)} could not be cloned
What am I doing wrong ?
Any help would be very appreciated