我正在尝试使用findAndModify操作来查找和更新文档。
Query: {'socket_id': data.socket_id, 'weapons.type': selectedWeapon, 'battleWeapons.type':selectedWeapon}
Update: {'$inc':{'weapons.$.nums':-1, 'battleWeapons.$.nums':-1}}我在我的回调函数中得到了doc (所以它是通过查询找到的),但在MongoDB文档中没有变化。同样的命令在mongo控制台中也可以正常工作。它改变了我需要的一切。我做错了什么?
所以整个命令看起来是这样的:
db.collection('users', function (err, collection) {
var condition = {'socket_id': data.socket_id, 'weapons.type': selectedWeapon, 'battleWeapons.type':selectedWeapon},
update = {'$inc':{'weapons.$.nums':-1, 'battleWeapons.$.nums':-1}};
collection.findAndModify(condition, [['_id','asc']], update, {'new': true}, function (err, item) {...
})});发布于 2013-06-14 18:27:47
在findAndModify中,还有一个可以设置的参数,用于返回旧文档(更新前)或新文档(更新后)。我猜这一定是问题所在。为了确认,对于现有的findAndModify()命令,在运行此命令后,请检查mongo控制台中的更新文档,它必须进行更改。
https://stackoverflow.com/questions/17106133
复制相似问题