使用CLI连接到我们的Mongo实例,您可以使用更新修饰符运算符:
db.users.update({昵称: 'mcoalson'},{ "$ addToSet":{room_ref: "B"}})db.users.update({昵称: 'mcoalson'},{ "$ addToSet":{ room_ref: "C"}})db.users.findOne({昵称: 'mcoalson'}){ "_id":的ObjectId( "4de5e9e982e9556c2a000003"), "昵称": "mcoalson", "room_ref":[ "一" ,"d","b","c"]}
但是,在同一文档的node.js中执行完全相同的操作没有结果.
db.User.update({'nickname': 'mcoalson'}, {"$pullAll": {'room_ref': ["b"]}});
db.User.update({'nickname': 'mcoalson'}, {"$addToSet": {'room_ref': "f"}});
Run Code Online (Sandbox Code Playgroud)
"room_ref":["a","d","b","c"]
显然,"b"未被删除,并且未添加"f".我已经尝试了所有可以想到的引用场景,我能想到却没有任何变化.我可以使用node.js代码中的find()和findOne()并使用相同的凭据,任何建议?