我知道我可以在 update 中使用管道聚合器来用另一个字段的值更新一个值的字段。但是,我的问题是基于嵌套字段的值更新字段值时。更新的结果总是发出带括号的新字段。我不想要括号/数组,我只想要它是一个值。见下面的代码 https://mongoplayground.net/p/7ZDP8CYtKK3
db={
"players": [
{
"_id": ObjectId("5fba17c1c4566e57fafdcd7e"),
"username": "moshe",
"health": 0,
"maxHealth": 200,
"Chapters": [
{"Cat A": 25,
"Cat B": 100,
"Cat C": 125}]
}
]
}
这是我在下面应用的查询
db.players.update(
{username: "moshe"},
[{"$set": {"health": "$Chapters.Cat A"}}]
)
结果产生
[{"Chapters": [
{"Cat A": 25,
"Cat B": 100,
"Cat C": 125}],
"_id": ObjectId("5fba17c1c4566e57fafdcd7e"),
"health": [25],
"maxHealth": 200,
"username": "moshe"
}]
我想要的是在没有数组括号的情况下显示健康更新...... "health":25
这也是一个基于我正在使用的更大的数据库的示例。
答案 0 :(得分:0)
您可以使用 $arrayElemAt 或 $first(v4.4) 运算符从数组中选择第一个元素,
db.players.update(
{ username: "moshe" },
[{
"$set": {
"health": {
"$arrayElemAt": ["$Chapters.Cat A", 0]
}
}
}]
)