Python Mongodb 修改文檔

Python Mongodb 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 文檔已修改

查看數據是否已修改:

Python Mongodb Python Mongodb