这似乎是一个愚蠢的问题,但我还没有找到答案。如果我只是想将相同的字段-> 值添加到 MongoDB 集合中的每条记录,那么合适的 shell 命令是什么?我尝试使用空白查询 ({}) 进行多重更新,但这导致了这个错误:
多重更新仅适用于 $ 运算符
我对如何解决这个问题感到有些困惑。有什么建议吗?
最佳答案
错误说明了一切:您只能使用 $
modifier operators 修改多个文档.你可能有这样的事情:
> db.coll.update({ }, { a: 'b' }, false, true);
如果 multi
为 false,通常替换集合中的第一个对象为 { a: 'b' }
。您不会想用同一个文档替换集合中的所有对象!
使用 $set
operator而是:
> db.coll.update({ }, { '$set': { a: 'b' } }, false, true);
这会将每个文档的 a
属性(根据需要创建)设置为 'b'
。
关于MongoDB:无条件更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5587677/