亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Python應用中使用MongoDB的方法

發布時間:2020-08-05 15:52:13 來源:億速云 閱讀:214 作者:小新 欄目:編程語言

小編給大家分享一下在Python應用中使用MongoDB的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在這篇文章中,將向您展示如何使用Python鏈接目前主流的MongoDB(V3.4.0)數據庫,主要使用PyMongo(v3.4.0)和

MongoEngine(V0.10.7)。同時比較SQL和NoSQL

1、SQL vs NoSQL

如果你不是很熟悉NoSQL這個概念,MongoDB就是一個NoSQL數據庫。近幾年來它越來越受到整個行業的歡迎。NoSQL數據庫提供了一個和關系型數據庫非常不同的檢索方式和存儲數據功能。

在NoSQL出現的幾十年來,SQL數據庫是開發者尋求構建大型、可擴展系統的唯一選擇之一。然而,越來越多的需求要求存儲復雜數據結構的能力。這推動了NoSQL數據庫的誕生,它允許開發者存儲異構和無結構的數據。

當到數據庫方案選擇時,大多數人都問自己最后一個問題,“SQL或NoSQL的?”。無論是SQL和NoSQL都有自己的長處和弱點,你應該選擇適合您的應用需求中最好的之一。這里是兩者之間的一些區別:

SQL

模型是關系型的;數據被存放在表中;適用于每條記錄都是相同類型并具有相同屬性的情況;存儲規范需要預定義結構;添加新的屬性意味著你必須改變整體架構;ACID事務支持;

NoSQL

模型是非關系型的;可以存儲Json、鍵值對等(決定于NoSQL數據庫類型);并不是每條記錄都要有相同的結構;添加帶有新屬性的數據時,不會影響其他;支持ACID事務,根據使用的NoSQL的數據庫而有所不同;一致性可以改變;橫向擴展;

在兩種類型的數據庫之間還有許多其他的區別,但上面提到的是一些更重要的區別。根據您的具體情況,使用SQL數據庫可能是首選,而在其他情況下,NoSQL的是更明顯的選擇。當選擇一個數據庫時,您應該謹慎考慮每個數據庫的優勢和劣勢。

NoSQL的一個好處是,有許多不同類型的數據庫可供選擇,并且每個都有自己的用例:

key-value存儲:DynamoDB文檔存儲:CouchDB,MongoDB,RethinkDB列存儲:Cassandra數據結構: Redis,SSDB

還有很多,但這些是一些更常見的類型。近年來,SQL和NoSQL數據庫甚至已經開始合并。例如,PostgreSQL現在支持存儲和查詢JSON數據,很像MongoDB。有了這個,你可以用Postgres實現MongoDB一樣的功能,但你仍然沒有MongoDB的其他優勢(如橫向擴容和簡單的界面,等等)。

2、MongoDB

現在,讓我們將視線轉移到本文的重點,并闡明的MongoDB的具體的一些情況。

MongoDB是一個面向文檔的,開源數據庫程序,它平臺無關。MongoDB像其他一些NoSQL數據庫(但不是全部!)使用JSON結構的文檔存儲數據。這是使得數據非常靈活,不需要的Schema。

一些比較重要的特點是:

支持多種標準查詢類型,比如matching()、comparison (, )或者正則表達式;可以存儲幾乎任何類型的數據,無論是結構化,部分結構化,甚至是多態;要擴展和處理更多查詢,只需添加更多的機器;它是高度靈活和敏捷,讓您能夠快速開發應用程序;作為基于文檔的數據庫意味著您可以在單個文檔中存儲有關您的模型的所有信息;您可以隨時更改數據庫的Schema;許多關系型數據庫的功能也可以在MongoDB使用(如索引)。

在運行方面,MongoDB中有相當多的功能在其他數據庫中是沒有的:

無論您需要獨立服務器還是完整的獨立服務器集群,MongoDB都可以根據需要進行擴展;MongoDB還通過在各個分片上自動移動數據來提供負載均衡支持;它具有自動故障轉移支持,如果主服務器Down掉,新的主服務器將自動啟動并運行;MongoDB的管理服務(MMS)可以用于監控和備份MongoDB的基礎設施服務;不像關系數據庫,由于內存映射文件,你將節省相當多的RAM。

雖然起初MongoDB似乎是解決我們許多問題的數據庫,但它不是沒有缺點的。MongoDB的一個常見缺點是缺少對ACID事務的支持,MongoDB在特定場景下支持ACID事務,但不是在所有情況。在單文檔級別,支持ACID事務(這是大多數事務發生的地方)。但是,由于MongoDB的分布式性質,不支持處理多個文檔的事務。

MongoDB還缺少對自然join查詢支持。在MongoDB看來:文檔意在包羅萬象,這意味著,一般來說,它們不需要參考其他文檔。在現實世界中,這并不總是有效的,因為我們使用的數據是關系性的。因此,許多人認為MongoDB應該被用作一個SQL數據庫的補充數據庫,但是當你使用MongoDB是,你會發現這是錯誤的

3、PyMongo

現在我們已經描述了MongoDB的是什么,讓我們來看看如何在Python中實際使用它。由MongoDB開發者發布的官方驅動程序PyMongo,這里通過一些例子介紹,但你也應該查看完整的文檔,因為我們無法面面俱到。

當然第一件事就是安裝,最簡單的方式就是pip:

pip install pymongo==3.4.0

完成設置后,啟動的Python控制臺并運行以下命令:

>>> import pymongo

如果沒有提出任何異常就說明安裝成功了

使用MongoClient對象建立連接: 

from pymongo import MongoClient
client = MongoClient()

使用上面的代碼片段,將建立連接到默認主機(localhost)和端口(27017)。您還可以指定主機和/或使用端口:

client = MongoClient('localhost', 27017)

或者使用MongoURl格式:

client = MongoClient('mongodb://localhost:27017')

訪問數據庫

一旦你有一個連接的MongoClient實例,你可以在Mongo服務器中訪問任何數據庫。如果要訪問一個數據庫,你可以當作屬性一樣訪問:

db = client.pymongo_test

或者你也可以使用字典形式的訪問:

db = client['pymongo_test']

如果您的指定數據庫已創建,實際上并不重要。通過指定此數據庫名稱并將數據保存到其中,您將自動創建數據庫。

插入文檔

在數據庫中存儲數據,就如同調用只是兩行代碼一樣容易。第一行指定你將使用哪個集合。在MongoDB中術語中,一個集合是在數據庫中存儲在一起的一組文檔(相當于SQL的表)。集合和文檔類似于SQL表和行。第二行是使用集合插入數據insert_one()的方法:  

posts = db.posts
post_data = {
    'title': 'Python and MongoDB',
    'content': 'PyMongo is fun, you guys',
    'author': 'Scott'
}
result = posts.insert_one(post_data)
print('One post: {0}'.format(result.inserted_id))

我們甚至可以使用insert_one()同時插入很多文檔,如果你有很多的文檔添加到數據庫中,可以使用方法insert_many()。此方法接受一個list參數:

post_1 = {
    'title': 'Python and MongoDB',
    'content': 'PyMongo is fun, you guys',
    'author': 'Scott'
}
post_2 = {
    'title': 'Virtual Environments',
    'content': 'Use virtual environments, you guys',
    'author': 'Scott'
}
post_3 = {
    'title': 'Learning Python',
    'content': 'Learn Python, it is easy',
    'author': 'Bill'
}
new_result = posts.insert_many([post_1, post_2, post_3])
print('Multiple posts: {0}'.format(new_result.inserted_ids))

你應該看到類似輸出:

One post: 584d947dea542a13e9ec7ae6
Multiple posts: [
    ObjectId('584d947dea542a13e9ec7ae7'),
    ObjectId('584d947dea542a13e9ec7ae8'),
    ObjectId('584d947dea542a13e9ec7ae9')
]

注意: 不要擔心,你和上面顯示不一樣。它們是在插入數據時,由Unix的紀元,機器標識符和其他唯一數據組成的動態標識。

檢索文檔

檢索文檔可以使用find_one()方法,比如要找到author為Bill的記錄:

bills_post = posts.find_one({'author': 'Bill'})
print(bills_post)
 
運行結果:
{
    'author': 'Bill',
    'title': 'Learning Python',
    'content': 'Learn Python, it is easy',
    '_id': ObjectId('584c4afdea542a766d254241')
}

您可能已經注意到,這篇文章的ObjectId是設置的_id,這是以后可以使用唯一標識。如果需要查詢多條記錄可以使用find()方法:

scotts_posts = posts.find({'author': 'Scott'})
print(scotts_posts)

結果:

<pymongo.cursor.Cursor object at 0x109852f98>

他的主要區別在于文檔數據不是作為數組直接返回給我們。相反,我們得到一個游標對象的實例。這Cursor是一個包含相當多的輔助方法,以幫助您處理數據的迭代對象。要獲得每個文檔,只需遍歷結果:

for post in scotts_posts:
    print(post)

4、MongoEngine

雖然PyMongo是非常容易使用,總體上是一個偉大的輪子,但是許多項目使用它都可能太低水平。簡而言之,你必須編寫很多自己的代碼來持續地保存,檢索和刪除對象。PyMongo之上提供了一個更高的抽象一個庫是MongoEngine。MongoEngine是一個對象文檔映射器(ODM),它大致相當于一個基于SQL的對象關系映射器(ORM)。MongoEngine提供的抽象是基于類的,所以你創建的所有模型都是類。雖然有相當多的Python的庫可以幫助您使用MongoDB,MongoEngine是一個更好的,因為它有一個很好的組合的功能,靈活性和社區支持。

使用pip安裝:

pip install mongoengine==0.10.7

連接:

from mongoengine import *
connect('mongoengine_test', host='localhost', port=27017)

和pymongo不同。MongoEngine需要制定數據庫名稱。

定義文檔

建立文檔之前,需要定義文檔中要存放數據的字段。與許多其他ORM類似,我們將通過繼承Document類,并提供我們想要的數據類型來做到這一點:

import datetime
class Post(Document):
    title = StringField(required=True, max_length=200)
    content = StringField(required=True)
    author = StringField(required=True, max_length=50)
    published = DateTimeField(default=datetime.datetime.now)

在這個簡單的模型中,我們已經告訴MongoEngine,我們的Post實例有title、content、author、published。現在Document對象可以使用該信息來驗證我們提供它的數據。

因此,如果我們試圖保存Post的中沒有title那么它會拋出一個Exception,讓我們知道。我們甚至可以進一步利用這個并添加更多的限制:

required:設置必須;default:如果沒有其他值給出使用指定的默認值unique:確保集合中沒有其他document有此字段的值相同choices:確保該字段的值等于數組中的給定值之一

保存文檔

將文檔保存到數據庫中,我們將使用save()的方法。如果文檔中的數據庫已經存在,則所有的更改將在原子水平上對現有的文檔進行。如果它不存在,但是,那么它會被創建。

這里是創建和保存一個文檔的例子:

post_1 = Post(
    title='Sample Post',
    content='Some engaging content',
    author='Scott'
)
post_1.save()       # This will perform an insert
print(post_1.title)
post_1.title = 'A Better Post Title'
post_1.save()       # This will perform an atomic edit on "title"
print(post_1.title)

調用save()的時候需要注意幾點:

PyMongo將在您調用.save()時執行驗證,這意味著它將根據您在類中聲明的模式檢查要保存的數據,如果違反模式(或約束),則拋出異常并且不保存數據;由于Mongo不支持真正的事務,因此沒有辦法像在SQL數據庫中那樣“回滾”.save()調用。

當你保存的數據沒有title時:

post_2 = Post(content='Content goes here', author='Michael')
post_2.save()
raise ValidationError(message, errors=errors)
mongoengine.errors.ValidationError:
ValidationError (Post:None) (Field is required: ['title'])

面向對象的特性

使用MongoEngine是面向對象的,你也可以添加方法到你的子類文檔。例如下面的示例,其中函數用于修改默認查詢集(返回集合的所有對象)。通過使用它,我們可以對類應用默認過濾器,并只獲取所需的對象

class Post(Document):
    title = StringField()
    published = BooleanField()
 
    @queryset_manager
    def live_posts(clazz, queryset):
        return queryset.filter(published=True)

關聯其他文檔

您還可以使用ReferenceField對象來創建從一個文檔到另一個文檔的引用。MongoEngine在訪問時自動惰性處理引用。

class Author(Document):
    name = StringField()
 
class Post(Document):
    author = ReferenceField(Author)
 
Post.objects.first().author.name

在上面的代碼中,使用文檔”外鍵”,我們可以很容易地找到第一篇文章的作者。其實還有比這里介紹的更多的字段類(和參數),所以一定要查看文檔字段更多信息。

以上是在Python應用中使用MongoDB的方法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

舒兰市| 黔南| 汽车| 蓬安县| 友谊县| 黄平县| 麻江县| 金塔县| 南安市| 沈阳市| 两当县| 永平县| 炉霍县| 海伦市| 九龙城区| 琼海市| 大邑县| 饶河县| 桃江县| 海安县| 德令哈市| 连云港市| 库车县| 鸡西市| 淮阳县| 嘉黎县| 清苑县| 原平市| 通州区| 信宜市| 白玉县| 江油市| 沂南县| 乐安县| 太仆寺旗| 万盛区| 邻水| 茶陵县| 乌拉特前旗| 林州市| 洛川县|