Python Mongodb 修改文檔
我們可以在 MongoDB 中使用 update_one() 方法修改文檔中的記錄。該方法第一個參數為查詢的條件,第二個參數為要修改的字段。
如果查找到的匹配數據多餘一條,則只會修改第一條。
本文使用的測試數據如下(點擊圖片查看大圖):
以下實例將 alexa 字段的值 10000 改為 12345:
實例
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["zaixiandb"]
mycol = mydb["sites"]
myquery = { "alexa": "10000" }
newvalues = { "$set": { "alexa": "12345" } }
mycol.update_one(myquery, newvalues)
# 輸出修改後的 "sites" 集合
for x in mycol.find():
print(x)
執行輸出結果為:
update_one() 方法只能修匹配到的第一條記錄,如果要修改所有匹配到的記錄,可以使用 update_many()。
以下實例將查找所有以 F 開頭的 name 字段,並將匹配到所有記錄的 alexa 字段修改為 123:
實例
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["zaixiandb"]
mycol = mydb["sites"]
myquery = { "name": { "$regex": "^F" } }
newvalues = { "$set": { "alexa": "123" } }
x = mycol.update_many(myquery, newvalues)
print(x.modified_count, "文檔已修改")
輸出結果為:
1 文檔已修改
查看數據是否已修改: