如何实现同时更新N条数据中的某字段,让其自增

假设我查询到100条数据,每条数据中都有一个count字段(number类型),想让这100条数据的count字段全部自增,应该怎么做?

贴上我的代码:

       db.coll.update({
            someQuery: 'xxx'
        }, {$inc: {count: 1}}, false, true)

我这么做只能自增查询到的第一条,很困惑,望解答,感谢!

阅读 2.9k
1 个回答

问题原因:update参数设置错误,导致它等同于updateOne,仅匹配第一条数据,因此仅自增第一条。
解决办法:
1.还是用update,{multi:true}激活multi。

db.coll.update({
    someQuery: 'xxx'
}, {$inc: {count: 1}}, {multi:true})

2.改用updateMany,去掉true选项,自增所有数据。

db.coll.updateMany({
    someQuery: 'xxx'
}, {$inc: {count: 1}})
推荐问题