使用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基础教程之循环介绍
Aug 29 Python
Python入门篇之正则表达式
Oct 20 Python
深入浅析Python字符编码
Nov 12 Python
Python的Flask站点中集成xhEditor文本编辑器的教程
Jun 13 Python
简单谈谈Python中的反转字符串问题
Oct 24 Python
Python探索之爬取电商售卖信息代码示例
Oct 27 Python
python 定义给定初值或长度的list方法
Jun 23 Python
Python将列表数据写入文件(txt, csv,excel)
Apr 03 Python
TensorFlow车牌识别完整版代码(含车牌数据集)
Aug 05 Python
keras用auc做metrics以及早停实例
Jul 02 Python
解决PyCharm不在run输出运行结果而不是再Console里输出的问题
Sep 21 Python
浅谈Python项目的服务器部署
Apr 25 Python
python自动计算图像数据集的RGB均值
详解如何用Python实现感知器算法
python中24小时制转换为12小时制的方法
Jun 18 #Python
用Python selenium实现淘宝抢单机器人
python中pandas对多列进行分组统计的实现
python 常用的异步框架汇总整理
Jun 18 #Python
Opencv中cv2.floodFill算法的使用
You might like
我的论坛源代码(九)
2006/10/09 PHP
php $_SERVER["REQUEST_URI"]获取值的通用解决方法
2010/06/21 PHP
php插入中文到sqlserver 2008里出现乱码的解决办法分享
2012/07/19 PHP
从PHP $_SERVER相关参数判断是否支持Rewrite模块
2013/09/26 PHP
php实现快速排序的三种方法分享
2014/03/12 PHP
PHP调用API接口实现天气查询功能的示例
2017/09/21 PHP
ThinkPHP框架实现定时执行任务的两种方法分析
2018/09/04 PHP
用javascript获得地址栏参数的两种方法
2006/11/08 Javascript
纯JAVASCRIPT图表动画插件Highcharts Examples
2011/04/16 Javascript
如何创建一个JavaScript弹出DIV窗口层的效果
2013/09/25 Javascript
asm.js使用示例代码
2013/11/28 Javascript
javascript删除字符串最后一个字符
2014/01/14 Javascript
setInterval与clearInterval的使用示例代码
2014/01/28 Javascript
Express作者TJ告别Node.js奔向Go
2014/07/14 Javascript
详解AngularJS Filter(过滤器)用法
2015/12/28 Javascript
Angular.JS实现无限级的联动菜单(使用demo)
2017/02/08 Javascript
微信小程序开发之好友列表字母列表跳转对应位置
2017/09/26 Javascript
微信小程序实现图片上传功能实例(前端+PHP后端)
2018/01/10 Javascript
vue.js通过路由实现经典的三栏布局实例代码
2018/07/08 Javascript
vue.js template模板的使用(仿饿了么布局)
2018/08/13 Javascript
Django+vue跨域问题解决的详细步骤
2019/01/20 Javascript
React精髓!一篇全概括小结(急速)
2019/05/23 Javascript
JavaScript生成随机验证码代码实例
2019/09/28 Javascript
Vue3新特性之在Composition API中使用CSS Modules
2020/07/13 Javascript
在vue中获取wangeditor的html和text的操作
2020/10/23 Javascript
浅谈Python中的可变对象和不可变对象
2017/07/07 Python
Anaconda 离线安装 python 包的操作方法
2018/06/11 Python
Python两台电脑实现TCP通信的方法示例
2019/05/06 Python
HTML5中实现拖放效果无须借助javascript
2012/12/26 HTML / CSS
NFL欧洲商店(德国):NFL Europe Shop DE
2018/11/03 全球购物
应届医学毕业生求职信分享
2013/12/02 职场文书
会计专业应届生自荐信
2014/02/07 职场文书
2014年发展党员工作总结
2014/11/12 职场文书
2016学校先进党组织事迹材料
2016/02/29 职场文书
nginx基于域名,端口,不同IP的虚拟主机设置的实现
2021/03/31 Servers
德劲DE1102数字调谐收音机机评
2022/04/07 无线电