在pymongo的Upsert和多旗子

时间:2013-02-17 19:28:50

标签: python mongodb pymongo

我正在研究pymongo,这是我的文件:

{
   "_id": ObjectId("51211b57f07ddaa377000000"),
   "assignments": {
     "0": {
       "0": {
         "_id": ObjectId("5120dd7400a4453d58a0d0ec") 
      },
       "1": {
         "_id": ObjectId("5120dd8e00a4453d58a0d0ed") 
      },
       "2": {
         "_id": ObjectId("5120ddad00a4453d58a0d0ee") 
      } 
    } 
  },
   "password": "my_passwd",
   "username": "john" 
}

我想取消所有此类文档的“赋值”属性。 我能够通过以下方式在mongo shell上实现这一点:

db.users.update({}, {$unset: {"assignments": 1}}, false, true)

即,我将upsert和multi标志作为最后两个参数传递给users集合上的update function函数。 不过我用pymongo做了这个:

db.users.update({}, {"$unset": {"assignments": 1}}, False, True)

但是python解释器抛出了如下错误:

File "notes/assignment.py", line 34, in <module>
    db.users.update({}, {"$unset": {"assignments": 1}}, False, True)
  File "/usr/local/lib/python2.7/dist-packages/pymongo/collection.py", line 481, in update
    check_keys, self.__uuid_subtype), safe)
  File "/usr/local/lib/python2.7/dist-packages/pymongo/mongo_client.py", line 852, in _send_message
    rv = self.__check_response_to_last_error(response)
  File "/usr/local/lib/python2.7/dist-packages/pymongo/mongo_client.py", line 795, in __check_response_to_last_error
    raise OperationFailure(details["err"], details["code"])
pymongo.errors.OperationFailure: Modifiers and non-modifiers cannot be mixed

我哪里错了?

1 个答案:

答案 0 :(得分:28)

问题是您传入的两个标志不是upsertmulti。根据PyMongo Collection.update(找到here)的文档,看起来您可能会传递upsertmanipulate选项的值,但我不确定。

要解决这个问题,你需要做的就是使用Python最强大的功能之一:命名参数。通过指定要传递给update的选项,除了确保不会发生此类事故之外,还可以为代码添加清晰度。

在这种情况下,我们希望传递选项upsert=Falsemulti=True

db.users.update({}, { "$unset": { "assignments": 1 } }, upsert=False, multi=True)