Python MongoDB 更新

更新集合

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

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

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

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

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

  1. import pymongo
  2. myclient = pymongo.MongoClient("mongodb://localhost:27017/")
  3. mydb = myclient["mydatabase"]
  4. mycol = mydb["customers"]
  5. myquery = { "address": "Valley 345" }
  6. newvalues = { "$set": { "address": "Canyon 123" } }
  7. mycol.update_one(myquery, newvalues)
  8. #更新之后打印 "customers" :
  9. for x in mycol.find():
  10. print(x)

更新多个

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

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

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

分类导航