日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

如何用python 操作MongoDB數據庫

瀏覽:38日期:2022-06-22 09:46:10
一、前言

MongoDB屬于 NoSQL(非關系型數據庫),是一個基于分布式文件存儲的開源數據庫系統。

二、操作 MongoDB1、安裝 pymongo

python 使用第三方庫來連接操作 MongoDB,所以我們首先安裝此庫。

pip3 install pymongodb

2、連接 MongoDB

使用 MongoClient 類連接,以下兩種參數方式都可以:

from pymongo import MongoClient# 連接方式一client = MongoClient(host=’localhost’,port=27017)# 連接方式二# client = MongoClient(’mongodb://localhost:27017/’)3、選擇數據庫

MongoDB 可以創建很多 db,指定我們需要的 db 即可

# 方式一db = client.Monitor# 方式二# db = client[’Monitor’]4、選擇集合

db 內包含很多個集合,有點類似 mysql 這類關系型數據庫中的表

# 方式一collection = db.test# 方式二# collection = db[’test’]5、插入數據

插入一條數據,MongoDB 每條記錄都有一個唯一標識。返回一個 InsertOneResult 對象,若需要獲取唯一標識,找到 InsertOneResult 對象的屬性 inserted_id 即可

from pymongo import MongoClientclass mongodb: def __init__(self,host,db,port = 27017):’’’:param host: str mongodb地址:param db: str 數據庫:param port: int 端口,默認為27017’’’host = hostdb = dbself.port = portclient = MongoClient(host=host,port=port)self.db = client[db] def insert_one(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 要插入的字典:return: 返回一個包含ObjectId類型的對象’’’collection = self.db[table]rep = collection.insert_one(dic)return repif __name__==’__main__’: dic = {’姓名’:’小明’,’English’:100,’math’:90} db = mongodb(host=’localhost’,db = ’test’) rep = db.insert_one(’test’,dic) print(rep.inserted_id)

插入多條數據,使用 insert_many 批量插入

from pymongo import MongoClientclass mongodb: def __init__(self,host,db,port = 27017):’’’:param host: str mongodb地址:param db: str 數據庫:param port: int 端口,默認為27017’’’host = hostdb = dbself.port = portclient = MongoClient(host=host,port=port)self.db = client[db] def insert_one(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 要插入的字典:return: 返回包含一個ObjectId類型的對象’’’collection = self.db[table]rep = collection.insert_one(dic)return rep def insert_many(self,table,lists):’’’:param table: str 數據庫中的集合:param dic: dict 要插入的列表,列表中的元素為字典:return: 返回包含多個ObjectId類型的列表對象’’’collection = self.db[table]rep = collection.insert_many(lists)return repif __name__==’__main__’: lists = [{’姓名’:’小明’,’English’:100,’math’:90}, {’姓名’:’小華’,’English’:90,’math’:100}] db = mongodb(host=’localhost’,db = ’test’) rep = db.insert_many(’test’,lists) for i in rep.inserted_ids:print(i)6、查詢

1)常規查詢

find_one :查詢單條記錄,返回一個字典。 find:查詢多條記錄 ,返回一個游標對象。

from pymongo import MongoClientclass mongodb: def __init__(self,host,db,port = 27017):’’’:param host: str mongodb地址:param db: str 數據庫:param port: int 端口,默認為27017’’’host = hostdb = dbself.port = portclient = MongoClient(host=host,port=port)self.db = client[db] def find_one(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 查詢條件:return: dict 返回單條記錄的字典’’’collection = self.db[table]rep = collection.find_one(dic)return rep def find(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 查詢條件:return: list 返回查詢到記錄的列表’’’collection = self.db[table]rep = list(collection.find(dic))return repif __name__==’__main__’: # 查詢 English 成績為 100 的所有記錄 dic = {’English’:100} db = mongodb(host=’localhost’,db = ’test’) rep = db.insert_many(’test’,dic) print(rep)

2)范圍查詢

有時候我們需要范圍比較查詢,比如要查詢 English 成績為 80~90 ,可以使用比較符:dic = {’English’:{’$in’:[80,90]}}

$lt :小于 $lte:小于等于 $gt:大于 $gte:大于等于 $ne:不等于 $in:在范圍內 $nin:不在范圍內

3)計數

直接調用 count() 方法,返回一個 int 類型的數字

# 計數查詢只需要在普通查詢后加上 count() 即可count = collection.find().count() # count = collection.find({’English’:{’$gt’:90}}).count()

4)排序

排序時,直接調用sort()方法,并在其中傳入排序的字段及升降序標志,返回一個游標對象

# 正序 ASCENDING,倒序 DESCENDING。list()將游標對象轉成列表data = list(collection.find(dic).sort(’姓名’,pymongo.DESCENDING))7、更新數據

首選查到需要更新的數據,然后將該數據更新,返回一個 UpdataResult 對象, raw_result 屬性中包含 update 生效的個數。

update_one:更新查詢到的第一條數據 update_many:更新多條數據

from pymongo import MongoClientclass mongodb: def __init__(self,host,db,port = 27017):’’’:param host: str mongodb地址:param db: str 數據庫:param port: int 端口,默認為27017’’’host = hostdb = dbself.port = portclient = MongoClient(host=host,port=port)self.db = client[db] def update_one(self,table,condition,dic):’’’:param table: str 數據庫中的集合:param condition: dict 查詢條件:param dic: dict 更新的數據:return: 返回UpdateResult對象’’’collection = self.db[table]# $set 表示只更新dic字典內存在的字段rep = collection.update_one(condition,{’$set’:dic})# 會把之前的數據全部用dic字典替換,如果原本存在其他字段,則會被刪除# rep = collection.update_one(condition, dic)return rep def update_many(self,table,condition,dic):’’’:param table: str 數據庫中的集合:param condition: dict 查詢條件:param dic: dict 更新的數據:return:返回UpdateResult對象’’’collection = self.db[table]# $set 表示只更新dic字典內存在的字段rep = collection.update_many(condition,{’$set’:dic})# 會把之前的數據全部用dic字典替換,如果原本存在其他字段,則會被刪除# rep = collection.update_many(condition, dic)return repif __name__==’__main__’: condition = {’English’:80} dic = {’English’:60} db = mongodb(host=’mongodb-monitor.monitor.svc.test.local’,db = ’test’) rep = db.update_one(’test’,condition,dic) print(rep.raw_result) # 輸出 {’n’: 1, ’nModified’: 1, ’ok’: 1.0, ’updatedExisting’: True}8、刪除

刪除和 update 類似,刪除數據后,返回一個 DeleteResult 對象, raw_result 屬性中包含 delete 的個數

delete_one:刪除查詢到的第一條數據 delete_many:批量刪除符合查詢條件的數據

from pymongo import MongoClientclass mongodb: def __init__(self,host,db,port = 27017):’’’:param host: str mongodb地址:param db: str 數據庫:param port: int 端口,默認為27017’’’host = hostdb = dbself.port = portclient = MongoClient(host=host,port=port)self.db = client[db] def delete_one(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 查詢條件:return: 返回DeleteResult對象’’’collection = self.db[table]rep = collection.delete_one(dic)return rep def delete_many(self,table,dic):’’’:param table: str 數據庫中的集合:param dic: dict 查詢條件:return: 返回DeleteResult對象’’’collection = self.db[table]rep = collection.delete_many(dic)return repif __name__==’__main__’: dic = {’English’:60} db = mongodb(host=’localhost’,db = ’test’) rep = db.delete_many(’test’,dic) print(rep.raw_result) # 輸出 {’n’: 21, ’ok’: 1.0}

以上就是如何用python 操作MongoDB數據庫的詳細內容,更多關于python 操作MongoDB數據庫的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久精品成人| 高清不卡一区| 狠狠干综合网| 亚洲欧美视频| 午夜精品福利影院| 老色鬼久久亚洲一区二区| 国产一区导航| 中文字幕av一区二区三区四区| 男女激情视频一区| 国产精品亚洲综合久久| 免费在线欧美黄色| 视频福利一区| 亚洲欧美久久精品| 精品无人区麻豆乱码久久久| 免费观看亚洲| 免费看黄色91| 久久精品日韩欧美| 久久久久午夜电影| 日韩精品一区二区三区免费视频| 精品国产网站| 免费观看久久av| 欧美精品福利| 蜜桃成人av| 久久尤物视频| 三级一区在线视频先锋| 精品一区视频| 综合国产视频| av在线日韩| 久久精品 人人爱| 91精品99| 精品久久97| 91精品日本| 日本大胆欧美人术艺术动态| 福利一区和二区| 欧美日本久久| 在线日韩中文| 日本一区二区免费高清| 青草国产精品久久久久久| 美女少妇全过程你懂的久久| 欧美欧美黄在线二区| 中文一区二区| 久久久久99| 精品成人18| 国产精品videossex| 亚洲精品黄色| 亚洲欧美日本国产专区一区| 亲子伦视频一区二区三区| 国产一区二区三区亚洲综合| 国产欧美日韩一区二区三区四区| 蜜臀av国产精品久久久久| 精品一区二区三区亚洲| 国产精品色婷婷在线观看| 日韩高清不卡一区二区| 日本成人手机在线| 亚洲精品第一| 青青草国产成人99久久| 国产欧美日韩精品一区二区免费 | 欧美激情三区| 日韩精品久久久久久| 国产亚洲一区二区三区不卡| 日本一区二区三区视频在线看| 蜜桃视频在线观看一区二区| 国产亚洲永久域名| 亚洲一区二区av| 日韩精品亚洲专区在线观看| 亚洲精品第一| 久久不卡日韩美女| 国产成人77亚洲精品www| 国产拍在线视频| 久久九九精品| 香蕉久久国产| 日本v片在线高清不卡在线观看| 日本午夜精品视频在线观看| 亚洲精品第一| 日韩福利视频导航| 国产精品国产三级国产在线观看| 另类专区亚洲| 日韩专区欧美专区| 乱一区二区av| 欧美中文一区二区| 日韩精品久久久久久久软件91| 黄色精品视频| 国产亚洲午夜| 欧美精品1区| 狠狠干成人综合网| 欧美一区在线观看视频| 婷婷综合六月| 国产精品久久久亚洲一区| 成人午夜网址| 日韩精品中文字幕吗一区二区 | 日韩久久电影| 日韩一区二区三区精品视频第3页| 久久免费视频66| 快she精品国产999| 麻豆视频在线看| 奇米狠狠一区二区三区| 香蕉久久精品| 久久久91麻豆精品国产一区| 香蕉久久国产| 丁香婷婷久久| 日韩一区二区三区精品 | 国产精品免费不| 黑丝一区二区三区| 一区二区三区四区日本视频| 欧美日韩黄网站| 亚洲欧洲美洲国产香蕉| 精品日韩视频| 精品国产乱码久久久| 国产亚洲字幕| 四虎精品永久免费| 国产亚洲永久域名| 国产综合欧美| 国产精品国产一区| 日韩精品久久理论片| 欧美在线资源| 不卡视频在线| 欧美91福利在线观看| 久久久人人人| 亚洲不卡av不卡一区二区| 成人在线观看免费视频| 欧美激情综合| 久久久久九九精品影院| 欧美91在线| 蜜桃精品视频| 精品72久久久久中文字幕| 国产成人免费精品| 精品国产午夜肉伦伦影院| 欧美激情aⅴ一区二区三区| 日韩专区视频网站| 日韩精品视频在线看| 日本天堂一区| 麻豆一区二区在线| 亚洲黄色免费看| 久久久久久黄| 久久午夜精品一区二区| 日本a口亚洲| 你懂的国产精品| 91精品推荐| 麻豆久久精品| 国产精品成人一区二区网站软件| 久久不见久久见免费视频7| 欧美激情视频一区二区三区在线播放| 国产一区二区三区黄网站| 欧美成人a交片免费看| 国产在线成人| 一区二区91| 成人在线免费观看网站| 五月精品视频| 国产一精品一av一免费爽爽| 国产网站在线| 老牛影视一区二区三区| 国产精品巨作av| 国产高清一区二区| 欧美精品国产一区| 午夜精品久久久久久久久久蜜桃| 亚洲黄色影院| 久久一区欧美| 蜜臀久久99精品久久久久久9| 国产亚洲高清在线观看| 正在播放日韩精品| 日韩美女精品| 宅男噜噜噜66国产日韩在线观看| 麻豆精品在线| 亚洲精品少妇| 女主播福利一区| 国产成人精品一区二区免费看京| 免费看精品久久片| 色婷婷精品视频| 久久精品国产亚洲aⅴ| 日韩中文字幕在线一区| 91精品一区二区三区综合| 国产精品国码视频| 日本va欧美va欧美va精品| 国产麻豆久久| 国产精品亚洲综合久久| 亚洲欧美专区| 国产精品美女久久久浪潮软件| 国产精品精品国产一区二区| 国产亚洲欧美日韩精品一区二区三区| 亚洲欧美成人综合| 亚洲精品成人| 亚洲男女av一区二区| 日韩精品一区二区三区免费观看| 国产中文字幕一区二区三区| 国产日韩一区二区三免费高清| 亚洲欧洲专区| 免费观看在线综合色| 乱人伦精品视频在线观看| 欧美亚洲国产精品久久| 国产美女高潮在线| 一本大道色婷婷在线| 92国产精品| 1000部精品久久久久久久久| 日韩精品欧美| 欧美日韩国产探花| 久久国产精品毛片| 亚洲乱码视频| 麻豆视频久久| 欧美激情另类| 91精品一区国产高清在线gif |