高效使用 PyMongo 进行 MongoDB 查询和插入操作
插入到集合中:
要將記錄(在MongoDB中稱為文檔)插入到集合中,使用insert_one()方法。insert_one()方法的第一個(gè)參數(shù)是一個(gè)包含文檔中每個(gè)字段的名稱和值的字典。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
mydict = { "name": "John", "address": "Highway 37" }
x = mycol.insert_one(mydict)
返回 _id 字段:
insert_one()方法返回一個(gè)InsertOneResult對(duì)象,該對(duì)象具有一個(gè)屬性inserted_id,其中包含插入的文檔的ID。
mydict = { "name": "Peter", "address": "Lowstreet 27" }
x = mycol.insert_one(mydict)
print(x.inserted_id)
插入多個(gè)文檔:
要在MongoDB中的集合中插入多個(gè)文檔,使用insert_many()方法。insert_many()方法的第一個(gè)參數(shù)是包含要插入的數(shù)據(jù)的字典列表。
mylist = [
{ "name": "Amy", "address": "Apple st 652"},
{ "name": "Hannah", "address": "Mountain 21"},
{ "name": "Michael", "address": "Valley 345"},
# ...
]
x = mycol.insert_many(mylist)
# 打印插入文檔的 _id 值列表
print(x.inserted_ids)
插入多個(gè)文檔,指定ID:
如果不希望MongoDB為文檔分配唯一的ID,可以在插入文檔時(shí)指定 _id 字段。確保這些值是唯一的,兩個(gè)文檔不能具有相同的 _id。
mylist = [
{ "_id": 1, "name": "John", "address": "Highway 37"},
{ "_id": 2, "name": "Peter", "address": "Lowstreet 27"},
{ "_id": 3, "name": "Amy", "address": "Apple st 652"},
# ...
]
x = mycol.insert_many(mylist)
# 打印插入文檔的 _id 值列表
print(x.inserted_ids)
查找一個(gè):
要從MongoDB集合中選擇數(shù)據(jù),可以使用find_one()方法,它返回選擇中的第一個(gè)文檔。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
x = mycol.find_one()
print(x)
查找所有:
要從MongoDB集合中選擇所有文檔,可以使用find()方法。在find()方法中不指定參數(shù)會(huì)給出與SQL中的SELECT *相同的結(jié)果。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
for x in mycol.find():
print(x)
僅返回部分字段:
如果想僅返回部分字段,可以在find()方法的第二個(gè)參數(shù)中指定要包含在結(jié)果中的字段。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
for x in mycol.find({}, {"_id": 0, "name": 1, "address": 1}):
print(x)
不允許在同一對(duì)象中同時(shí)指定0和1值:
不允許在同一對(duì)象中同時(shí)指定0和1值,除非其中一個(gè)字段是 _id 字段。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
# 會(huì)出現(xiàn)錯(cuò)誤,因?yàn)橥瑫r(shí)指定了0和1值
for x in mycol.find({}, {"name": 1, "address": 0}):
print(x)
高級(jí)查詢:
要進(jìn)行高級(jí)查詢,可以在查詢對(duì)象中使用修飾符作為值。例如,使用大于修飾符 $gt 可以查找 "address" 字段以字母 "S" 或更高字母(按字母順序)開頭的文檔。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
myquery = { "address": { "$gt": "S" } }
mydoc = mycol.find(myquery)
for x in mydoc:
print(x)
使用正則表達(dá)式過濾:
您還可以使用正則表達(dá)式作為修飾符,但正則表達(dá)式只能用于查詢字符串。
例如,要僅查找 "address" 字段以字母 "S" 開頭的文檔,可以使用正則表達(dá)式 {"$regex": "^S"}。
import pymongo
myclient = pymongo.MongoClient("mongodb://localhost:27017/")
mydb = myclient["mydatabase"]
mycol = mydb["customers"]
myquery = { "address": { "$regex": "^S" } }
mydoc = mycol.find(myquery)
for x in mydoc:
print(x)
最后
為了方便其他設(shè)備和平臺(tái)的小伙伴觀看往期文章:公眾號(hào)搜索Let us Coding,或者掃描下方二維碼,關(guān)注公眾號(hào),即可獲取最新文章。
看完如果覺得有幫助,歡迎點(diǎn)贊、收藏和關(guān)注
總結(jié)
以上是生活随笔為你收集整理的高效使用 PyMongo 进行 MongoDB 查询和插入操作的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【Flutter】一文读懂混入类Mixi
- 下一篇: Android app的暗黑模式适配实现