Първа опция --> Използване на агрегиране
Тъй като някои от документите ви във вашата колекция може да съдържат или да не съдържат permissions
поле или типът не е равен на масив, поради което получавате тази грешка.
Можете да намерите $type
на полето и ако не е масив или не съществува във вашия документ, можете да го добавите като масив с $addFields
и $cond
агрегиране
db.collection.aggregate([
{ "$addFields": {
"permissions": {
"$cond": {
"if": {
"$ne": [ { "$type": "$permissions" }, "array" ]
},
"then": [],
"else": "$permissions"
}
}
}},
{ "$project": {
"filteredChildren": {
"$filter": {
"input": "$moduleChildren",
"as": "moduleChild",
"cond": {
"$in": [ "$$moduleChild._id", "$permissions" ]
}
}
}
}}
])
Втора опция -->
Отидете до вашата mongo shell или robomongo на всеки GUI, който използвате, и изпълнете тази команда
db.collection.update(
{ "permissions": { "$ne": { "$type": "array" } } },
{ "$set": { "permissions": [] } },
{ "multi": true }
)