- エラーには
$mapと表示されます のinput$を使用して参照フィールドを受け入れます$versionに署名します 、 -
uを囲みます で更新するための、配列ブラケット内のオブジェクト集約パイプライン - 両方のフィールド
titleを入力するだけです およびversion$mapで -
$unset$mapなので、必要ありません。inの古いデータを新しいフィールドに置き換えます
db.runCommand({
update: 'apps',
updates: [
{
q: { "versions.name": { $exists: true } },
u: [{
$set: {
versions: {
$map: {
input: "$versions",
in: {
"title": "$$this.name",
"version": "$$this.version"
}
}
}
}
}],
multi: true
}
]
})
第二に、よりダイナミックなアプローチのために
-
$mergeObjects$map内 、キーと値のペアが手動でリストされないようにするため -
$unsetnameを削除するステージversionのフィールド 配列
db.runCommand({
update: 'apps',
updates: [
{
q: { "versions.name": { $exists: true } },
u: [
{
$set: {
versions: {
$map: {
input: "$versions",
in: {
$mergeObjects: [
"$$this",
{ "title": "$$this.name" }
]
}
}
}
}
},
{ $unset: "versions.name" }
],
multi: true
}
]
})