注意:请使用 mongodb shell 执行代码。
假设我有一份学生文件如下
{
"_id" : 4,
"grades" : [
{
"grade" : 80,
"mean" : 75,
"std" : 8
},
{
"grade" : 85,
"mean" : 90,
"std" : 5
},
{
"grade" : 85,
"mean" : 90,
"std" : 5
},
{
"grade" : 85,
"mean" : 95,
"std" : 6
},
{
"grade" : 90,
"mean" : 85,
"std" : 5
}
]
}
我们有两个问题:
问题 1:假设你想用 _id=4 && grades.grade = 85 && grades.std = 5 更新所有子文档,std=6 你会写如下
db.students.update( {'$and':[ { _id: 4},{ "grades.grade": 85 }, {"grades.std": 5 } ]}, { $set: { "grades.$.std" : 6 } } );
现在,如果您多次执行上述语句(3 次),那么理想情况下它应该更新第 2、3 个子文档
但是最后一个子文档也正在更新,因为它有 std=5 匹配,但是我们给出的条件是$ 而不是$or,那么最后一个文档怎么会更新呢?
问题 2: 现在假设您要删除与查询条件匹配的子文档本身。我尝试了以下声明
db.students.update({_id:4,'grades.grade':85},{'$unset':{'grades.$':1}})
因为 $unset 会在子文档/数组的情况下设置 null,如何解决这个问题?
如何在您的 mongodb 控制台中复制?
db.students.insert( { "_id" : 4, "grades" : [ { grade: 80, mean: 75, std: 8 }, { grade: 85, mean: 90, std: 5 }, { grade: 85, mean: 90, std: 5 }, { grade: 85, mean: 95, std: 6 }, { grade: 90, mean: 85, std: 5 } ] });