假设我查询到100条数据,每条数据中都有一个count
字段(number类型),想让这100条数据的count
字段全部自增,应该怎么做?
贴上我的代码:
db.coll.update({
someQuery: 'xxx'
}, {$inc: {count: 1}}, false, true)
我这么做只能自增查询到的第一条,很困惑,望解答,感谢!
假设我查询到100条数据,每条数据中都有一个count
字段(number类型),想让这100条数据的count
字段全部自增,应该怎么做?
贴上我的代码:
db.coll.update({
someQuery: 'xxx'
}, {$inc: {count: 1}}, false, true)
我这么做只能自增查询到的第一条,很困惑,望解答,感谢!
3 回答2.5k 阅读✓ 已解决
1 回答880 阅读✓ 已解决
2 回答1.1k 阅读
1 回答803 阅读✓ 已解决
2 回答1.6k 阅读
2 回答571 阅读✓ 已解决
2 回答986 阅读
问题原因:update参数设置错误,导致它等同于updateOne,仅匹配第一条数据,因此仅自增第一条。
解决办法:
1.还是用update,{multi:true}激活multi。
2.改用updateMany,去掉true选项,自增所有数据。