摘要:單條記錄插入江蘇注意接下來的操作中會(huì)忽略掉數(shù)據(jù)庫連接操作,直接寫核心代碼,請(qǐng)自行補(bǔ)上。江蘇我們?cè)匐S便插入點(diǎn)兒數(shù)據(jù)供下面操作使用。江蘇北京上海王二麻廣東條件查詢只要將查詢條件當(dāng)做參數(shù)塞入即可篩選數(shù)據(jù)。王二麻刪除全部數(shù)據(jù)慎用
Pymongo是python的一個(gè)操作Mongodb的庫。
下面我們直接簡列出一些常用操作命令。
連接數(shù)據(jù)庫鏈接數(shù)據(jù)庫需要提供一個(gè)地址和接口即可。首先還是要導(dǎo)入包。
from pymongo import MongoClient conn = MongoClient("localhost",27017)
當(dāng)然,你可以使用如下寫法:
conn = MongoClient("mongodb://localhost:27017/")創(chuàng)建數(shù)據(jù)庫
mongodb不需要提前創(chuàng)建好數(shù)據(jù)庫,而是直接使用,如果發(fā)現(xiàn)沒有則自動(dòng)創(chuàng)建。
db = conn.testdb
上面的語句,會(huì)創(chuàng)建一個(gè)testdb的數(shù)據(jù)庫。但是,在沒有插入數(shù)據(jù)的時(shí)候,該數(shù)據(jù)庫在管理工具里面你是看不到的(不顯示)。
插入數(shù)據(jù)首先第一步我們先插入一條數(shù)據(jù)瞧瞧。
單條記錄插入from pymongo import MongoClient conn = MongoClient("mongodb://localhost:27017/") db = conn.testdb db.col.insert({"name":"yanying","province":"江蘇","age":25})
注意: 接下來的操作中會(huì)忽略掉數(shù)據(jù)庫連接操作,直接寫核心代碼,請(qǐng)自行補(bǔ)上。
python控制臺(tái)什么都沒有發(fā)生,這就是成功的意思。使用管理工具查看數(shù)據(jù)庫記錄,的確包含了一條數(shù)據(jù)。
多條記錄插入Mongodb一次也可以插入多條數(shù)據(jù)
db.col.insert([ {"name":"yanying","province":"江蘇","age":25}, {"name":"張三","province":"浙江","age":24}, {"name":"張三1","province":"浙江1","age":25}, {"name":"張三2","province":"浙江2","age":26}, {"name":"張三3","province":"浙江3","age":28}, ])查詢數(shù)據(jù)
下面我們將剛剛插入的數(shù)據(jù)查詢出來。
單條查詢我們可以使用find_one()來查詢一條記錄。
db.col.find_one()
上面的語句可以查詢出一條mongodb記錄。記錄中多出來的_id是Mongodb自動(dòng)生成的唯一值。
{"_id": ObjectId("5925351ad92fac3250b9ae3f"), "name": "yanying", "province": "江蘇", "age": 25}
我們?cè)匐S便插入點(diǎn)兒數(shù)據(jù)供下面操作使用。(省略幾萬字)
查詢所有如果我們需要查詢出所有的記錄,則可以使用db.col.find()但是查出來的是一個(gè)結(jié)果資源集。
我們可以使用for來列出所有記錄。
for item in db.col.find(): print(item)
這樣可以獲取所有記錄。
{"_id": ObjectId("5925351ad92fac3250b9ae3f"), "name": "yanying", "province": "江蘇", "age": 25} {"_id": ObjectId("592550e5d92fac0b8c449f87"), "name": "zhangsan", "province": "北京", "age": 29} {"_id": ObjectId("592550f6d92fac3548c20b1a"), "name": "lisi", "province": "上海", "age": 22} {"_id": ObjectId("59255118d92fac43dcb1999a"), "name": "王二麻", "province": "廣東", "age": 30}條件查詢
只要將查詢條件當(dāng)做參數(shù)塞入即可篩選數(shù)據(jù)。
for item in db.col.find({"name":"yanying"}): print(item)
查詢結(jié)果
{"_id": ObjectId("5925351ad92fac3250b9ae3f"), "name": "yanying", "province": "江蘇", "age": 25}
當(dāng)然還可以查詢小于某個(gè)值的記錄
for item in db.col.find({"age":{"$lt":25}}): print(item)
或者大于某個(gè)值的記錄
for item in db.col.find({"age":{"$gt":25}}): print(item)統(tǒng)計(jì)查詢
上面的代碼可以統(tǒng)計(jì)出所有的記錄數(shù)量
db.col.find().count() // 4
或者加點(diǎn)兒條件
db.col.find({"age":{"$gt":25}}).count() //2根據(jù)_id查詢記錄
_id是mongodb自動(dòng)生成的id,其類型為ObjectId,想要使用就需要轉(zhuǎn)換類型。
python3中提供了該方法,不過需要導(dǎo)入一個(gè)庫。
from bson.objectid import ObjectId
這樣就可以直接使用_id進(jìn)行查詢啦。
collection.find_one({"_id":ObjectId("592550e5d92fac0b8c449f87")})結(jié)果排序
只要將需要排序的字段放入sort方法即可,Mongodb默認(rèn)為升序
db.col.find().sort("age")
不過你也可以加一些參數(shù)去改變排序的方式。比如倒序,不過要記得先導(dǎo)入pymongo庫
import pymongo db.col.find().sort("UserName",pymongo.DESCENDING)
你還可以讓他升序,盡管默認(rèn)如此
for item in db.col.find().sort("age",pymongo.ASCENDING): print(item)更新數(shù)據(jù)
更新數(shù)據(jù)很簡單,只需要一個(gè)條件和需要更新的數(shù)據(jù)即可
db.col.update({"_id":ObjectId("59255118d92fac43dcb1999a")},{"$set":{"name":"王二麻33333"}})
結(jié)果如下:王二麻變成了王二麻33333
{"_id": ObjectId("59255118d92fac43dcb1999a"), "name": "王二麻33333", "province": "廣東", "age": 30}刪除數(shù)據(jù)
刪除數(shù)據(jù)使用remove()方法,如果方法帶條件,則刪除指定條件數(shù)據(jù),否則刪除全部
刪除name為王二麻33333的用戶。
db.col.remove({"name":"王二麻33333"})
刪除全部數(shù)據(jù)(慎用)
db.col.remove()
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/44417.html
摘要:單條記錄插入江蘇注意接下來的操作中會(huì)忽略掉數(shù)據(jù)庫連接操作,直接寫核心代碼,請(qǐng)自行補(bǔ)上。江蘇我們?cè)匐S便插入點(diǎn)兒數(shù)據(jù)供下面操作使用。江蘇北京上海王二麻廣東條件查詢只要將查詢條件當(dāng)做參數(shù)塞入即可篩選數(shù)據(jù)。王二麻刪除全部數(shù)據(jù)慎用 Pymongo是python的一個(gè)操作Mongodb的庫。 下面我們直接簡列出一些常用操作命令。 連接數(shù)據(jù)庫 鏈接數(shù)據(jù)庫需要提供一個(gè)地址和接口即可。首先還是要導(dǎo)入包。...
摘要:課程簡介簡明易懂的課程,不僅適用于那些有其它語言基礎(chǔ)的同學(xué),對(duì)沒有編程經(jīng)驗(yàn)的同學(xué)也非常友好。建議遵守以下約定使用個(gè)空格來縮進(jìn)永遠(yuǎn)不要混用空格和制表符在函數(shù)之間空一行在類之間空兩行字典,列表,元組以及參數(shù)列表中,在后添加一個(gè)空格。 showImg(https://segmentfault.com/img/bVCldE); 課程簡介:簡明易懂的 Python3 課程,不僅適用于那些有其它語...
摘要:如果你仍然無法抉擇,那請(qǐng)選擇,畢竟這是未來的趨勢(shì),參考知乎回答還是編輯器該如何選我推薦社區(qū)版,配置簡單功能強(qiáng)大使用起來省時(shí)省心,對(duì)初學(xué)者友好。 這是一篇 Python 入門指南,針對(duì)那些沒有任何編程經(jīng)驗(yàn),從零開始學(xué)習(xí) Python 的同學(xué)。不管你學(xué)習(xí)的出發(fā)點(diǎn)是興趣驅(qū)動(dòng)、拓展思維,還是工作需要、想要轉(zhuǎn)行,都可以此文作為一個(gè)參考。 在這個(gè)信息爆炸的時(shí)代,以 Python入門 為關(guān)鍵字搜索出...
摘要:在配置的時(shí)候使用絕對(duì)路徑替代相對(duì)路徑,有利于在排查故障時(shí)查找進(jìn)程啟動(dòng)的目錄。在添加授權(quán)用戶和開啟認(rèn)證后,這些警告會(huì)自動(dòng)消失。投影文檔中字段為或真值表示包含,或假值表示排除,可以設(shè)置多個(gè)字段為或,但不能混合使用。 MongoDB 是免費(fèi)開源的跨平臺(tái) NoSQL 數(shù)據(jù)庫,命名源于英文單詞 humongous,意思是「巨大無比」,可見開發(fā)組對(duì) MongoDB 的定位。與關(guān)系型數(shù)據(jù)庫不同,Mo...
閱讀 2411·2021-09-08 09:45
閱讀 3356·2021-09-08 09:45
閱讀 3104·2019-08-30 15:54
閱讀 3358·2019-08-26 13:54
閱讀 1413·2019-08-26 13:26
閱讀 1391·2019-08-26 13:23
閱讀 914·2019-08-23 17:57
閱讀 2183·2019-08-23 17:14