1

以下是来自https://docs.mongodb.com/manual/reference/operator/update/positional/#examples的修改示例

db.students.insert([
   { "_id" : 1, "grades" : [ 85, 80, 80 ] },
   { "_id" : 2, "grades" : [ 88, 90, 92 ] },
   { "_id" : 3, "grades" : [ 85, 100, 90 ] }
])

db.students.updateOne(
   { _id: 1, grades: 80 },
   { $set: { "grades.$" : 82 } }
   { multi: true }
)'

我希望{multi: true}更新与选择器标准匹配的多个文档。

事实上,以下似乎也不起作用:

db.students.insert([
       { "_id" : 1, "grades" : [ 85, 82, 82 ] },
       { "_id" : 2, "grades" : [ 88, 90, 92 ] },
       { "_id" : 3, "grades" : [ 80, 100, 90 ] }
    ])

    db.students.updateOne(
       { _id: 1, grades: 80 },
       { $set: { "grades.$" : 82 } }
       { multi: true }
    )'

我希望将第三个文档更新为{"_id" : 3, "grades" : [82, 100, 90]}

4

1 回答 1

1

您的查询子句是{ _id: 1, grades: 80 }but id:1has grades : [ 85, 82, 82 ]。第三个文档将不会更新,因为它_id:3与您的查询子句不匹配。

专业提示:在运行之前update执行 afind以预览可能更新的内容*。

 db.students.find({ _id: 1, grades: 80 })

*find将返回所有匹配项,同时updateOne最多更新 1 个文档,但至少您会知道您的查询子句有效。

于 2019-03-30T21:21:02.543 回答