2012-01-30 197 views
2

我试图执行一个简单的更新,但数据没有在数据库中更新。 在下面的代码片段,我:pymongo更新不起作用

  1. 创建一个新帐户,并将其插入到数据库(成功
  2. 取回(成功
  3. 更新它(失败

这一切都在localhost,默认实例,没有涉及副本完成。 我一步步跟着文档,但是,不知道我做错了什么。

from pymongo import Connection 
from pymongo.objectid import ObjectId 

def _byid(id): 
    return ObjectId(id) 

class Account(object): 
    collection = Connection().testdb.accounts 

    def insert(self, data): 
     return self.collection.insert(data) 

    def byid(self, id): 
     return self.collection.find({"_id": _byid(id)}) 

    def update(self, id, data): 
     return self.collection.update({"_id": _byid(id)}, {"$set": data}) 

acc_data = { 
    "contact_name": "Mr. X", 
    "company_name": "Awesome Inc.", 
} 

account = Account() 

# INSERT 
_id = account.insert(acc_data) 
print 'ID:', _id 

# RETRIVE 
for ac in account.byid(_id):  
    print ac["company_name"] 

# UPDATE 
acc_data["company_name"] = acc_data["company_name"][::-1].upper() 
print account.update(_id, acc_data) 

# RETRIVE AGAIN 
for ac in account.byid(_id):  
    print ac["company_name"] 

回答

3

明白了。 更新应该是:

def update(self, id, data): 
    return self.collection.update({"_id": _byid(id)}, data)  

无需"$set"