Djongo的項(xiàng)目官方地址為:https://nesdis.github.io/djongo/,我們可以通過(guò)pip命令直接安裝djongo:
pip install djongo
在安裝完成之后,我們就可以直接在Django中配置MongoDB數(shù)據(jù)庫(kù)的信息了。
在正常情況下,我們的Django項(xiàng)目中數(shù)據(jù)庫(kù)在settings.py文件中進(jìn)行配置,其一般配置如下所示:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), } }
而我們使用Djongo的話,變化也不大,如下所示:
DATABASES = { 'default': { 'ENGINE': 'djongo', 'NAME': 'MongoDB數(shù)據(jù)庫(kù)的名稱', } }
可以發(fā)現(xiàn),這與Django原始的數(shù)據(jù)庫(kù)配置方法是一模一樣的,所不同的是,數(shù)據(jù)庫(kù)的引擎使用了djongo而非Django官方提供的數(shù)據(jù)庫(kù)封裝引擎。
我們用一個(gè)新的Django項(xiàng)目來(lái)演示一下djongo的使用。
首先創(chuàng)建Django項(xiàng)目和應(yīng)用:
然后修改項(xiàng)目的settings.py文件,填寫MongoDB數(shù)據(jù)庫(kù)的配置信息,Djongo提供了如下參數(shù)供我們?cè)O(shè)置數(shù)據(jù)庫(kù)的信息:
DATABASES = { 'default': { 'ENGINE': 'djongo', 'ENFORCE_SCHEMA': True, 'NAME': 'your-db-name', 'HOST': 'host-name or ip address', 'PORT': port_number, 'USER': 'db-username', 'PASSWORD': 'password', 'AUTH_SOURCE': 'db-name', 'AUTH_MECHANISM': 'SCRAM-SHA-1', 'REPLICASET': 'replicaset', 'SSL': 'ssl', 'SSL_CERTFILE': 'ssl_certfile', 'SSL_CA_CERTS': 'ssl_ca_certs', 'READ_PREFERENCE': 'read_preference' } }
我們的數(shù)據(jù)庫(kù)是本地的數(shù)據(jù)庫(kù),所以只需要設(shè)置一部分信息即可,其如下所示:
DATABASES = { 'default': { 'ENGINE': 'djongo', 'ENFORCE_SCHEMA': True, 'NAME': 'djongo_example', 'HOST': '127.0.0.1', 'PORT': 27017, } }
這樣,MongoDB在Django中的 配置就完成了,我們下面可以定義一些模型。
Djongo的一大特點(diǎn)是可以無(wú)縫地銜接Django的ORM語(yǔ)法,包括模型定義的語(yǔ)法和模型操作的語(yǔ)法?,F(xiàn)在,我們就為Django項(xiàng)目定義一些模型。
在默認(rèn)情況下,Django應(yīng)用的模型在其目錄下的models.py文件中定義。models.py文件初始化狀態(tài)下只有如下一行代碼:
from django.db import models
這是Django數(shù)據(jù)庫(kù)封裝的模型類,我們需要將其修改為Djongo提供的模型類,如下所示:
from djongo import models
然后,就可以按照Django的方式來(lái)定義模型了。在這里,我們定義了一個(gè)News()模型,用于存儲(chǔ)新聞:
class News(models.Model): title = models.CharField(verbose_name="標(biāo)題",max_length=50) author = models.CharField(verbose_name="作者",max_length=10) desc = models.CharField(verbose_name="簡(jiǎn)介",max_length=100) content = models.TextField(verbose_name="正文") create_time = models.DateTimeField(auto_now_add=True) update_time = models.DateTimeField(auto_now=True,auto_now_add=True) def __str__(self): return self.title class Meta: verbose_name = '新聞' verbose_name_plural = verbose_name
定義好模型之后,繼續(xù)按照Django模型的使用方式,生成數(shù)據(jù)庫(kù)遷移,并執(zhí)行遷移:
python manage.py makemigrations app python manage.py migrate
命令的執(zhí)行信息如下所示:
和使用SQL數(shù)據(jù)庫(kù)一樣,Django為新項(xiàng)目創(chuàng)建了我們定義的模型還有一些認(rèn)證管理相關(guān)的表,這是否是真的呢,我們?nèi)ongoDB數(shù)據(jù)庫(kù)里面查看一下:
MongoDB數(shù)據(jù)庫(kù)里面果然生成了一系列的數(shù)據(jù)表。
經(jīng)過(guò)上面的演示,我們可以發(fā)現(xiàn)借助于Djongo模塊,我們可以無(wú)痛地以Django ORM的方式來(lái)使用MongoDB數(shù)據(jù)庫(kù)。那么作為Django重量級(jí)的admin后臺(tái)功能,是否能夠支持呢?我們繼續(xù)下面的演示。
首先,繼續(xù)在命令行中創(chuàng)建一個(gè)超級(jí)用戶:
python manage.py createsuperuser
其過(guò)程與使用其他SQL數(shù)據(jù)庫(kù)無(wú)異:
接著,我們將剛剛創(chuàng)建的News()模型添加到admin中,在admin.py中進(jìn)行設(shè)置:
from app.models import News admin.site.register(News)
隨后,運(yùn)行測(cè)試服務(wù)器:
除此之外,我們最關(guān)心的還是對(duì)數(shù)據(jù)操縱是否方便。我們先在后臺(tái)界面嘗試一下新增數(shù)據(jù):
顯示新增成功了,我們?nèi)ongoDB里面看看是否存在:
經(jīng)過(guò)上面初步的演示在Django中借助djongo模塊來(lái)使用MongoDB,可以發(fā)現(xiàn)其還是很方便的,優(yōu)點(diǎn)在于其改動(dòng)微乎其微,兼容性特別強(qiáng)。推薦大家在測(cè)試環(huán)境下充分地進(jìn)行測(cè)試使用,如果沒(méi)有問(wèn)題,那么可以謹(jǐn)慎在生產(chǎn)環(huán)境中進(jìn)行部署。更多的使用方法和問(wèn)題,大家可以訪問(wèn)djongo項(xiàng)目官網(wǎng):https://nesdis.github.io/djongo/ 和它的GitHub項(xiàng)目地址:https://github.com/nesdis/djongo/
以上就是使用Djongo模塊在Django中使用MongoDB數(shù)據(jù)庫(kù)的詳細(xì)內(nèi)容,更多關(guān)于在Django中使用MongoDB數(shù)據(jù)庫(kù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
標(biāo)簽:長(zhǎng)春 洛陽(yáng) 泉州 清遠(yuǎn) 怒江 安慶 岳陽(yáng) 吉林
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Djongo模塊在Django中使用MongoDB數(shù)據(jù)庫(kù)》,本文關(guān)鍵詞 使用,Djongo,模塊,在,Django,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。