本篇文章主要介紹了詳解Python3操作Mongodb簡明易懂教程,詳細的介紹瞭如何連接資料庫和對資料庫的操作,有需要的可以了解一下。
連接資料庫
連結資料庫需要提供一個位址和介面即可。首先還是要導入包。
from pymongo import MongoClient conn = MongoClient('localhost',27017)
當然,你可以使用以下寫法:
conn = MongoClient('mongodb://localhost:27017/')
mongodb不需要事先建立好資料庫,而是直接使用,如果發現沒有則自動建立。
db = conn.testdb
上面的語句,會建立一個testdb的資料庫。但是,在沒有插入資料的時候,該資料庫在管理工具裡面你是看不到的(不顯示)。
插入資料
首先第一步我們先插入一條資料瞧瞧。
單一記錄插入
from pymongo import MongoClient conn = MongoClient('mongodb://localhost:27017/') db = conn.testdb db.col.insert({"name":'yanying','province':'江苏','age':25})
注意: 接下來的操作中會忽略掉資料庫連線操作,直接寫核心程式碼,請自行補上。
python控制台什麼都沒發生,這就是成功的意思。使用管理工具檢視資料庫記錄,的確包含了一則資料。
多筆記錄插入
#Mongodb一次也可以插入多條資料
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}, ])
查詢資料
下面我們將剛剛插入的資料查詢出來。
單一查詢
我們可以使用find_one()來查詢一筆記錄。
db.col.find_one()
上面的語句可以查詢出一筆mongodb記錄。記錄中多出來的_id是Mongodb自動產生的唯一值。
複製程式碼 程式碼如下:
{'_id': ObjectId('5925351ad92fac3250b9ae3f'), 'name': 'yanying', 'province': '江苏', 'age': 25}
我們再隨便插入點兒資料供下面操作使用。 (省略幾萬字)
查詢所有
#如果我們需要查詢出所有的記錄,則可以使用db.col.find( )但是查出來的是結果資源集合。
我們可以使用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}
條件查詢
只要將查詢條件當做參數塞入即可篩選資料。
for item in db.col.find({'name':"yanying"}): print(item)
查詢結果
程式碼如下:
{'_id': ObjectId('5925351ad92fac3250b9ae3f'), 'name': 'yanying', 'province': '江苏', 'age': 25}
當然也可以查詢小於某個值的記錄
for item in db.col.find({"age":{"$lt":25}}): print(item)
或大於某個值的記錄
for item in db.col.find({"age":{"$gt":25}}): print(item)
統計查詢
上面的程式碼可以統計出所有的記錄數量
db.col.find().count() // 4
或加點兒條件
db.col.find({"age":{"$gt":25}}).count() //2
根據_id查詢記錄
#_id是mongodb自動產生的id,其類型為ObjectId,想要使用就需要轉換類型。
python3中提供了這個方法,不過需要匯入一個函式庫。
from bson.objectid import ObjectId
這樣就可以直接使用_id來查詢啦。
collection.find_one({'_id':ObjectId('592550e5d92fac0b8c449f87')})
結果排序
只要將需要排序的欄位放入sort方法即可,Mongodb預設為升序
db.col.find().sort("age")
不過你也可以加一些參數去改變排序的方式。例如倒序,不過要記得先導入pymongo庫
import pymongo db.col.find().sort("UserName",pymongo.DESCENDING)
你還可以讓他升序,儘管預設如此
for item in db.col.find().sort('age',pymongo.ASCENDING): print(item)
##更新資料
複製程式碼 程式碼如下:
db.col.update({'_id':ObjectId('59255118d92fac43dcb1999a')},{'$set':{'name':'王二麻33333'}})結果如下:王二麻變成了王二麻33333程式碼如下:
{'_id': ObjectId('59255118d92fac43dcb1999a'), 'name': '王二麻33333', 'province': '广东', 'age': 30}
刪除資料
##刪除數據使用remove()方法,如果方法帶條件,則刪除指定條件數據,否則刪除全部
刪除name為王二麻33333的用戶。
db.col.remove({'name':'王二麻33333'})
刪除全部資料(慎用)
db.col.remove()
以上是關於Python3操作Mongodb的簡單明了的教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

mongodb php扩展没有的解决办法:1、在linux中执行“$ sudo pecl install mongo”命令来安装MongoDB的PHP扩展驱动;2、在window中,下载php mongodb驱动二进制包,然后在“php.ini”文件中配置“extension=php_mongo.dll”即可。

MongoDB是一种高性能、开源、文档型的NoSQL数据库,被广泛应用于Web应用、大数据以及云计算领域。而Go语言则是一种快速、开发效率高、代码可维护性强的编程语言。本文将为您完整介绍如何在Go语言中使用MongoDB。一、安装MongoDB在使用MongoDB之前,需要先在您的系统中安装MongoDB。在Linux系统下,可以通过如下命令安装:sudo

Redis和MongoDB都是流行的开源NoSQL数据库,但它们的设计理念和使用场景有所不同。本文将重点介绍Redis和MongoDB的区别和使用场景。Redis和MongoDB简介Redis是一个高性能的数据存储系统,常被用作缓存和消息中间件。Redis以内存为主要存储介质,但它也支持将数据持久化到磁盘上。Redis是一款键值数据库,它支持多种数据结构(例

php7.0安装mongo扩展的方法:1、创建mongodb用户组和用户;2、下载mongodb源码包,并将源码包放到“/usr/local/src/”目录下;3、进入“src/”目录;4、解压源码包;5、创建mongodb文件目录;6、将文件复制到“mongodb/”目录;7、创建mongodb配置文件并修改配置即可。

MongoDB作为一款流行的NoSQL数据库,已经被广泛应用于各种大型Web应用和企业级应用中。而PHP语言也作为一种流行的Web编程语言,与MongoDB的结合也变得越来越重要。在本文中,我们将会学习如何使用PHP语言操作MongoDB数据库进行增删查改的操作。

自定义Appender非常简单,继承一下AppenderBase类即可。可以看到有个AppenderBase,有个UnsynchronizedAppenderBase,还有个AsyncAppenderBase继承了UnsynchronizedAppenderBase。从名字就能看出来区别,异步的、普通的、不加锁的。我们定义一个MongoDBAppender继承UnsynchronizedAppenderBasepublicclassMongoDBAppenderextendsUnsynchron

一、什么是MongoDBMongoDB与我们之前熟知的关系型数据库(MySQL、Oracle)不同,MongoDB是一个文档数据库,它具有所需的可伸缩性和灵活性,以及所需的查询和索引。MongoDB将数据存储在灵活的、类似JSON的文档中,这意味着文档的字段可能因文档而异,数据结构也会随着时间的推移而改变。文档模型映射到应用程序代码中的对象,使数据易于处理。MongoDB是一个以分布式数据库为核心的数据库,因此高可用性、横向扩展和地理分布是内置的,并且易于使用。况且,MongoDB是免费的,开源

在现代企业应用程序开发中,需要处理海量数据和高并发的访问请求。为了满足这些需求,开发人员需要使用高性能的数据库系统,以确保系统的稳定性和可扩展性。本文将介绍如何使用Swoole和MongoDB构建高性能的文档数据库系统。Swoole是一个基于PHP语言开发的异步网络通信框架,它能够大大提高PHP应用程序的性能和并发能力。MongoDB是一种流行的文档数据库,


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3漢化版
中文版,非常好用