Python MongoDB 更新

更新集合

您可以使用 update_one() 方法来更新 MongoDB 中调用的记录或文档。

update_one() 方法的第一个参数是 query 对象,用于定义要更新的文档。

注释:如果查询找到多个记录,则仅更新第一个匹配项。

第二个参数是定义文档新值的对象。

实例

把地址 "Valley 345" 改为 "Canyon 123":

  1. import pymongo
  2.  
  3. myclient = pymongo.MongoClient("mongodb://localhost:27017/")
  4. mydb = myclient["mydatabase"]
  5. mycol = mydb["customers"]
  6.  
  7. myquery = { "address": "Valley 345" }
  8. newvalues = { "$set": { "address": "Canyon 123" } }
  9.  
  10. mycol.update_one(myquery, newvalues)
  11.  
  12. #print "customers" after the update:
  13. for x in mycol.find():
  14. print(x)

更新多个

如需更新符合查询条件的所有文档,请使用 update_many() 方法。

实例

更新地址以字母 "S" 开头的所有文档:

  1. import pymongo
  2.  
  3. myclient = pymongo.MongoClient("mongodb://localhost:27017/")
  4. mydb = myclient["mydatabase"]
  5. mycol = mydb["customers"]
  6.  
  7. myquery = { "address": { "$regex": "^S" } }
  8. newvalues = { "$set": { "name": "Minnie" } }
  9.  
  10. x = mycol.update_many(myquery, newvalues)
  11.  
  12. print(x.modified_count, "documents updated.")