使用Djongo模块在Django中使用MongoDB数据库


Posted in Python onJune 20, 2021
目录
  • 一、安装与配置
  • 二、定义模型
  • 三、生成模型
  • 四、访问Django Admin
  • 五、操作数据
  • 六、最后

 

一、安装与配置

Djongo的项目官方地址为:https://nesdis.github.io/djongo/,我们可以通过pip命令直接安装djongo:

pip install djongo

在安装完成之后,我们就可以直接在Django中配置MongoDB数据库的信息了。

在正常情况下,我们的Django项目中数据库在settings.py文件中进行配置,其一般配置如下所示:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

而我们使用Djongo的话,变化也不大,如下所示:

DATABASES = {
    'default': {
        'ENGINE': 'djongo',
        'NAME': 'MongoDB数据库的名称',
    }
}

可以发现,这与Django原始的数据库配置方法是一模一样的,所不同的是,数据库的引擎使用了djongo而非Django官方提供的数据库封装引擎。

我们用一个新的Django项目来演示一下djongo的使用。

首先创建Django项目和应用:

使用Djongo模块在Django中使用MongoDB数据库

然后修改项目的settings.py文件,填写MongoDB数据库的配置信息,Djongo提供了如下参数供我们设置数据库的信息:

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'
   }
}

我们的数据库是本地的数据库,所以只需要设置一部分信息即可,其如下所示:

DATABASES = {
   'default': {
      'ENGINE': 'djongo',
      'ENFORCE_SCHEMA': True,
      'NAME': 'djongo_example',
      'HOST': '127.0.0.1',
      'PORT': 27017,
   }
}

这样,MongoDB在Django中的 配置就完成了,我们下面可以定义一些模型。

 

二、定义模型

Djongo的一大特点是可以无缝地衔接Django的ORM语法,包括模型定义的语法和模型操作的语法。现在,我们就为Django项目定义一些模型。

在默认情况下,Django应用的模型在其目录下的models.py文件中定义。models.py文件初始化状态下只有如下一行代码:

from django.db import models

这是Django数据库封装的模型类,我们需要将其修改为Djongo提供的模型类,如下所示:

from djongo import models

然后,就可以按照Django的方式来定义模型了。在这里,我们定义了一个News()模型,用于存储新闻:

class News(models.Model):
    title = models.CharField(verbose_name="标题",max_length=50)
    author = models.CharField(verbose_name="作者",max_length=10)
    desc = models.CharField(verbose_name="简介",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

 

三、生成模型

定义好模型之后,继续按照Django模型的使用方式,生成数据库迁移,并执行迁移:

python manage.py makemigrations app&
python manage.py migrate

命令的执行信息如下所示:

使用Djongo模块在Django中使用MongoDB数据库

和使用SQL数据库一样,Django为新项目创建了我们定义的模型还有一些认证管理相关的表,这是否是真的呢,我们去MongoDB数据库里面查看一下:

使用Djongo模块在Django中使用MongoDB数据库

MongoDB数据库里面果然生成了一系列的数据表。

 

四、访问Django Admin

经过上面的演示,我们可以发现借助于Djongo模块,我们可以无痛地以Django ORM的方式来使用MongoDB数据库。那么作为Django重量级的admin后台功能,是否能够支持呢?我们继续下面的演示。

首先,继续在命令行中创建一个超级用户:

python manage.py createsuperuser

其过程与使用其他SQL数据库无异:

使用Djongo模块在Django中使用MongoDB数据库

接着,我们将刚刚创建的News()模型添加到admin中,在admin.py中进行设置:

from app.models import News
admin.site.register(News)

随后,运行测试服务器:

使用Djongo模块在Django中使用MongoDB数据库

 

五、操作数据

除此之外,我们最关心的还是对数据操纵是否方便。我们先在后台界面尝试一下新增数据:

使用Djongo模块在Django中使用MongoDB数据库

显示新增成功了,我们去MongoDB里面看看是否存在:

使用Djongo模块在Django中使用MongoDB数据库

 

六、最后

经过上面初步的演示在Django中借助djongo模块来使用MongoDB,可以发现其还是很方便的,优点在于其改动微乎其微,兼容性特别强。推荐大家在测试环境下充分地进行测试使用,如果没有问题,那么可以谨慎在生产环境中进行部署。更多的使用方法和问题,大家可以访问djongo项目官网:https://nesdis.github.io/djongo/ 和它的GitHub项目地址:https://github.com/nesdis/djongo/

以上就是使用Djongo模块在Django中使用MongoDB数据库的详细内容,更多关于在Django中使用MongoDB数据库的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python写的一个squid访问日志分析的小程序
Sep 17 Python
详解Python中的序列化与反序列化的使用
Jun 30 Python
Python中列表、字典、元组数据结构的简单学习笔记
Mar 20 Python
python实现八大排序算法(2)
Sep 14 Python
微信跳一跳小游戏python脚本
Jan 05 Python
Python实现爬取百度贴吧帖子所有楼层图片的爬虫示例
Apr 26 Python
pandas 读取各种格式文件的方法
Jun 22 Python
在python里面运用多继承方法详解
Jul 01 Python
用Python爬取QQ音乐评论并制成词云图的实例
Aug 24 Python
Python3并发写文件与Python对比
Nov 20 Python
Python如何绘制日历图和热力图
Aug 07 Python
win10+anaconda安装yolov5的方法及问题解决方案
Apr 29 Python
python自动计算图像数据集的RGB均值
详解如何用Python实现感知器算法
python中24小时制转换为12小时制的方法
Jun 18 #Python
用Python selenium实现淘宝抢单机器人
python中pandas对多列进行分组统计的实现
python 常用的异步框架汇总整理
Jun 18 #Python
Opencv中cv2.floodFill算法的使用
You might like
基于mysql的bbs设计(四)
2006/10/09 PHP
php 图片加水印与上传图片加水印php类
2010/05/12 PHP
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
PHP 第三节 变量介绍
2012/04/28 PHP
php后门URL的防范
2013/11/12 PHP
php插件Xajax使用方法详解
2017/08/31 PHP
php进程(线程)通信基础之System V共享内存简单实例分析
2019/11/09 PHP
根据分辨率不同,调用不同的css文件
2006/08/25 Javascript
prototype 学习笔记整理
2009/07/17 Javascript
JavaScript实现班级随机点名小应用需求的具体分析
2014/05/12 Javascript
jQuery插件pagination实现分页特效
2015/04/12 Javascript
JavaScript实现的简单烟花特效代码
2015/10/20 Javascript
继续学习javascript闭包
2015/12/03 Javascript
JavaScript模块化开发之SeaJS
2015/12/13 Javascript
理解JavaScript表单的基础知识
2016/01/25 Javascript
JavaScript获取当前运行脚本文件所在目录的方法
2016/02/03 Javascript
基于vue.js的分页插件详解
2017/11/27 Javascript
js中let和var定义变量的区别
2018/02/08 Javascript
详解@Vue/Cli 3 Invalid Host header 错误解决办法
2019/01/02 Javascript
浅析webpack-bundle-analyzer在vue-cli3中的使用
2019/10/23 Javascript
JavaScript实现简单的图片切换功能(实例代码)
2020/04/10 Javascript
vue 避免变量赋值后双向绑定的操作
2020/11/07 Javascript
Vue Elenent实现表格相同数据列合并
2020/11/30 Vue.js
Python实现的二维码生成小软件
2014/07/11 Python
用Python实现斐波那契(Fibonacci)函数
2016/03/25 Python
python中字符串变二维数组的实例讲解
2018/04/03 Python
Python+OpenCV感兴趣区域ROI提取方法
2019/01/10 Python
PyQt+socket实现远程操作服务器的方法示例
2019/08/22 Python
python代码能做成软件吗
2020/07/24 Python
Django+Uwsgi+Nginx如何实现生产环境部署
2020/07/31 Python
CSS3 真的会替代 SCSS 吗
2021/03/09 HTML / CSS
J2EE模式面试题
2016/10/11 面试题
毕业生自我鉴定范文
2013/11/08 职场文书
幼儿园大班区域活动总结
2014/07/09 职场文书
小学总务工作总结
2015/08/13 职场文书
为了顺利买到演唱会的票用Python制作了自动抢票的脚本
2021/10/16 Python