用Python操作 MongoDB 數(shù)據(jù)庫(kù)

用 pymongo 操作 MongoDB 數(shù)據(jù)庫(kù)

1.連接數(shù)據(jù)庫(kù)

MongoDB 數(shù)據(jù)庫(kù)下載地址

你可以使用以下2種方法

# -*- coding: utf-8 -*-
#導(dǎo)入pymongo中的MongoClient模塊
from pymongo import MongoClient
#第一種方法:使用host和port
client1 = MongoClient(host,port)
#這里的host是一個(gè)ip地址,可以是本機(jī)的127.0.0.1,也可以是一個(gè)網(wǎng)絡(luò)地址,也就是說可以不在安裝MongoDB的情況下使用MongoDB
#第二種方法:使用mongodb url
url = 'mongodb://host:port/'
#當(dāng)數(shù)據(jù)庫(kù)有密碼的時(shí)候
url = 'mongodb://username:password@host:port/'#默認(rèn)進(jìn)入admin
client2 = MongoClient(url)
#當(dāng)MongoDB里面有多個(gè)數(shù)據(jù)庫(kù),分別是test1,test2...,可以通過下面的url形式來進(jìn)行訪問特定的數(shù)據(jù)庫(kù)
url = 'mongodb://username:password@host/database_name'

2.在增、刪凤优、改、查操作之前

也就是說一個(gè)MongoDB連接可以有多個(gè)database蜈彼,同一個(gè)database下可以有多個(gè)collection筑辨,一個(gè)collection下可以有多個(gè)document

from pymongo import MongoClient
client = MongoClient(host='127.0.0.1',port=27017)
#這個(gè)時(shí)候我們已經(jīng)連接上了數(shù)據(jù)庫(kù),但是還不能直接進(jìn)行具體操作,需要在集合的水平進(jìn)行具體操作
#建立一個(gè)名為china數(shù)據(jù)庫(kù)
china = client['china']
#在user的基礎(chǔ)上建立一個(gè)名為shandong的集合
shandong = china['shandong']
#至此我們可以在集合的基礎(chǔ)上進(jìn)行增幸逆、刪棍辕、改暮现、查的操作了

為了整齊,此處將上面的代碼進(jìn)行整合

# -*- coding: utf-8 -*-
from pymongo import MongoClient
client = MongoClient(host='127.0.0.1',port=27017)
collection = client['china']['shandong']

下面增、刪楚昭、改栖袋、查的操作都是在上面 collection這個(gè)對(duì)象的基礎(chǔ)上進(jìn)行操作

3.寫(增)操作

pymongo提供了 insert_one(), insert_more()兩個(gè)方法來進(jìn)行寫操作

#insert_one()接收一個(gè)字典對(duì)象collection.insert_one({'people_num':147000000})
#insert_many()接收一個(gè)字典列表
collection.insert_many([{'people_num':147000000},{'city_num':16}])
collection.insert_one({'people_num':147000000,'city_num':16,'location':"east"})

效果如下:

4.查操作

pymongo提供了 find_one(), find()兩個(gè)方法來進(jìn)行查操作 find_one方法

#默認(rèn)獲取集合中的第一條    
collection.find_one()
#按條件查詢,find_one()接收一個(gè)字典來進(jìn)行匹配
collection.find_one({'people_num':147000000})
#多條件查詢   
 collection.find_one({'people_num':147000000,'city_num':16})

find方法

#獲取集合中所有數(shù)據(jù)    
collection.find({})
#按條件查詢,find()接收一個(gè)字典來進(jìn)行匹配
collection.find({'people_num':147000000})  
#=>返回一個(gè)pymongo內(nèi)置的Cursor對(duì)象,是可迭代的,可以使用循環(huán)輸出
#按規(guī)則輸出數(shù)據(jù)項(xiàng),為1的輸出抚太,為0的不輸出    
collection.find({},{'_id':0,'city_num':1}) 
#==>含有city_num數(shù)據(jù)項(xiàng)的輸出city_num,沒有的輸出空字典
collection.find({},{'people_num':0,'city_num':1})
#這樣寫會(huì)報(bào)錯(cuò)塘幅,也就是find({},{query}),query中不能同時(shí)含有兩個(gè)數(shù)據(jù)項(xiàng)(_id除外)
#限制返回條數(shù)  .limit(n)當(dāng)n大于原本的數(shù)據(jù)數(shù)量時(shí),返回原數(shù)據(jù)量尿贫,當(dāng)小于時(shí)电媳,返回n條    
collection.find({}).limit(3) 
#返回三條#使用正則查詢    
collection.find({"location":{ "$regex":"e[a-z]+"}}) 
#=>匹配location的值是以e開頭后面有多個(gè)小寫字母的=>east
#更高級(jí)的查詢 使用修飾符
# $gt  匹配大于指定值的值
# $eq  匹配等于指定值的值
# $gte 匹配大于或等于指定值的值
# $in  匹配數(shù)組中指定的任何值
# $nin 不匹配數(shù)組中指定的任何值
# $lt  匹配小于指定值的值
# $lte 匹配小于或等于指定值的值
# $ne  匹配所有不等于指定值的值
# $and 用邏輯聯(lián)接查詢子句AND將返回兩個(gè)子句都匹配的所有文檔。
# $not 反轉(zhuǎn)查詢表達(dá)式的效果庆亡,并返回與查詢表達(dá)式不匹配的文檔匾乓。
# $nor 用邏輯聯(lián)接查詢子句NOR將返回兩個(gè)子句均不匹配的所有文檔。
# $or  用邏輯聯(lián)接查詢子句OR將返回符合任一子句條件的所有文檔又谋。
#更多修飾符請(qǐng)看 https://docs.mongodb.com/manual/reference/operator/query/  

collection.find({"people_num":{"$eq":147000000}})
 #匹配people_num的值等于147000000

5.改(更新)操作

pymongo提供了 update_one(), update_many()兩個(gè)方法來進(jìn)行查操作

#更新一條數(shù)據(jù)    
collection.update_one({'people_num':147000000},{"$set": { "people_num": "12345"}})
#更新多條數(shù)據(jù)    
collection.update_many({'city_num':16},{"$set": { "city_num": 100}})

6.刪操作

pymongo提供了 delete_one(), delete_many()兩個(gè)方法來進(jìn)行刪除操作拼缝,和查操作的使用方法一樣。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末搂根,一起剝皮案震驚了整個(gè)濱河市珍促,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌剩愧,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件娇斩,死亡現(xiàn)場(chǎng)離奇詭異仁卷,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)犬第,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門锦积,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人歉嗓,你說我怎么就攤上這事丰介。” “怎么了鉴分?”我有些...
    開封第一講書人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵哮幢,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我志珍,道長(zhǎng)橙垢,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任伦糯,我火速辦了婚禮柜某,結(jié)果婚禮上嗽元,老公的妹妹穿的比我還像新娘。我一直安慰自己喂击,他們只是感情好剂癌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著翰绊,像睡著了一般珍手。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上辞做,一...
    開封第一講書人閱讀 51,708評(píng)論 1 305
  • 那天琳要,我揣著相機(jī)與錄音,去河邊找鬼秤茅。 笑死稚补,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的框喳。 我是一名探鬼主播课幕,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼五垮!你這毒婦竟也來了乍惊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤放仗,失蹤者是張志新(化名)和其女友劉穎润绎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體诞挨,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡莉撇,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了惶傻。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片棍郎。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖银室,靈堂內(nèi)的尸體忽然破棺而出涂佃,到底是詐尸還是另有隱情,我是刑警寧澤蜈敢,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布辜荠,位于F島的核電站,受9級(jí)特大地震影響扶认,放射性物質(zhì)發(fā)生泄漏侨拦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一辐宾、第九天 我趴在偏房一處隱蔽的房頂上張望狱从。 院中可真熱鬧膨蛮,春花似錦、人聲如沸季研。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)与涡。三九已至惹谐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間驼卖,已是汗流浹背氨肌。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留酌畜,地道東北人怎囚。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像桥胞,于是被迫代替她去往敵國(guó)和親恳守。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355