日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > windows >内容正文

windows

高效使用 PyMongo 进行 MongoDB 查询和插入操作

發(fā)布時(shí)間:2023/11/16 windows 56 coder
生活随笔 收集整理的這篇文章主要介紹了 高效使用 PyMongo 进行 MongoDB 查询和插入操作 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

插入到集合中:

要將記錄(在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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。