热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

django和MongoDB

balabalaNoSQLMongoDB一个无任何特点的教师,他教导的学生不会有任何特点。今朝NoSQL还没有一个标准的定义,最常见的申明是non-relational,也有很多人申明为“NotOnlySQL”。NoSQL凡是意味着非关系型、分布式的数据存储,具备大数据量下的高机能,横
bala bala NoSQL & MongoDB
一个无任何特点的教师,他教导的学生不会有任何特点。今朝NoSQL还没有一个标准的定义,最常见的申明是"non-relational",也有很多人申明为“Not Only SQL”。NoSQL凡是意味着非关系型、分布式的数据存储,具备大数据量下的高机能,横向扩大才能,以及灵活的数据模型。也许,还意味着开源。
浪费时候就是自尽,尤其是浪费歇息的时候,直接威逼着生命。MongoDB是一种以文档情势存储的NoSQL。其首要的特点:
API: BSON
Protocol: lots of langs
Query Method: dynamic object-based language & MapReduce
Replication: Master Slave & Auto-Sharding
Written in: C++
Concurrency: Update in Place
Misc: Indexing, GridFS Links

Django对NoSQL的支撑
是的,Django将原生支撑NoSQL,然则不是如今。
你可能据说过django-nonrel 。即Django none relationship,非关系型的Django。django-nonrel供给了一层adapter,共同特定的backend,可以连接各类NoSQL。比如连接MongoDB的django-mongodb-engine。然则,django-nonrel 的实现是在内存中模仿SQL数据库操纵,这种思路没有获得Django核心的支撑,所以只能是一个外部版本。
query-refactor是GSoC(Google Summer of Code)的Django项目之一,已经进入Django的官方分支。query-refactor的作者Alex早已发布了query-refactor的“终极状况”。然则,因为该分支的完成时候与Django1.3的公布时候过于接近,所以没有赶上,在Django1.4的新特点清单docs.djangoproject.com—1.4中也没有找query-refactor的身影。若是有消息通晓人士不妨泄漏一下。
注:Alex并不是无名小卒,我们知道Django在1.2之前是不支撑多半据库的,恰是因为Alex的尽力,我们才干享用Django的多半据库特点。

Django + MongoDB的决定
最直接的体式格式是应用PyMongo——MongoDB供给的Python Driver。然则用惯了Django的Model层,其实不肯意本身去保护数据库连接,写一大堆CRUD的语句。
而django-nonrel,如前所述,未必是一个好的选择。同样的原因,django-mongodb-engine是基于django-nonrel的MongoDB backend实现,也不予推敲。
MongoEngine,在Django官方的支撑出来之前,我认为这是最好的选择。因为MongoEngine可以供给与Django Model(ORM)很是类似的体验,可以快速上手。看一下官网首页的例子:  mongoengine import *                           # To define a schema for a 
# document, we create a 
class Metadata(EmbeddedDocument):                   # class that inherits  
tags = ListField(StringField())                 # Document. 
revisions = ListField(IntField())               #
# Fields are specified by 
class WikiPage(Document):                           # adding field objects as 
title = StringField(required=True)              # class attributes to the 
text = StringField()                            # document class. 
metadata = EmbeddedDocumentField(Metadata)      # 
# Querying is achieved by 
>>> page.title = “Hello, World!”                    # calling the objects 
>>> for page in WikiPage.objects:                   # attribute on a document 
>>>     print page.title                            # class.

Django+MongoEngine 起首安装MongoEngine(依附pymongo)。之后在python shell中实验一下:
 mongoengine import *
connect(""employeeDB"")
class Employee(Document):
name = StringField(max_length=50)
age = IntField(required=False)
john = Employee(name="John Doe", age=25)
john.save()
jane = Employee(name="Jane Doe", age=27)
jane.save()
for e in Employee.objects.all():
print e["id"], e["name"], e["age"]
在Django中应用也很轻易,只需在models.py(若是你十分介怀,也可以零丁放在docs.py中)如许写:
 mongoengine import *
mysite.settings import DBNAME
connect(DBNAME)
class Employee(Document):
name = StringField(max_length=50)
age = IntField(required=False)
此中,DBNAME在settings.py中指定。
然后,在视图中就可以应用“文档模型“了。

其他
1.Mongo Engine的Field类型与Django ORM的Field类型有所不合,下面是一个简单的对比: 
MongoEngine Django
StringField CharField
URLField URLField
EmailField EmailField
IntField IntegerField
FloatField FloatField
DecimalField DecimalField
BooleanField BooleanField
DateTimeField DateTimeField
EmbeddedDocumentField --
DictField --
ListField --
SortedListField --
BinaryField --
ObjectIdField --
FileField FileField
2.尽管看起来像是ORM,但MongoDB绝对不是RDB。我想MongoEngine如许的设计是为了便利上手,然则应用的时辰,必然要遵守NoSQL的体式格式去思虑题目。
苏霍姆林斯基
推荐阅读
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • MongoDB核心概念详解
    本文介绍了NoSQL数据库的概念及其应用场景,重点解析了MongoDB的基本特性、数据结构以及常用操作。MongoDB是一个高性能、高可用且易于扩展的文档数据库系统。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 本文探讨了MariaDB在当前数据库市场中的地位和挑战,分析其可能面临的困境,并提出了对未来发展的几点看法。 ... [详细]
  • 本文详细介绍了Python编程语言的学习路径,涵盖基础语法、常用组件、开发工具、数据库管理、Web服务开发、大数据分析、人工智能、爬虫开发及办公自动化等多个方向。通过系统化的学习计划,帮助初学者快速掌握Python的核心技能。 ... [详细]
  • 58同城的Elasticsearch应用与平台构建实践
    本文由58同城高级架构师于伯伟分享,由陈树昌编辑整理,内容源自DataFunTalk。文章探讨了Elasticsearch作为分布式搜索和分析引擎的应用,特别是在58同城的实施案例,包括集群优化、典型应用实例及自动化平台建设等方面。 ... [详细]
  • 本文深入探讨了分布式文件系统的核心概念及其在现代数据存储解决方案中的应用,特别是针对大规模数据处理的需求。文章不仅介绍了多种流行的分布式文件系统和NoSQL数据库,还提供了选择合适系统的指导原则。 ... [详细]
  • 一家位于长沙的知名网络安全企业,现面向全国诚聘高级后端开发工程师,特别欢迎具有一线城市经验的技术精英回归故乡,共创辉煌。 ... [详细]
  • Redis:缓存与内存数据库详解
    本文介绍了数据库的基本分类,重点探讨了关系型与非关系型数据库的区别,并详细解析了Redis作为非关系型数据库的特点、工作模式、优点及持久化机制。 ... [详细]
  • 在CentOS 7环境中安装配置Redis及使用Redis Desktop Manager连接时的注意事项与技巧
    在 CentOS 7 环境中安装和配置 Redis 时,需要注意一些关键步骤和最佳实践。本文详细介绍了从安装 Redis 到配置其基本参数的全过程,并提供了使用 Redis Desktop Manager 连接 Redis 服务器的技巧和注意事项。此外,还探讨了如何优化性能和确保数据安全,帮助用户在生产环境中高效地管理和使用 Redis。 ... [详细]
  • 本文深入探讨了NoSQL数据库的四大主要类型:键值对存储、文档存储、列式存储和图数据库。NoSQL(Not Only SQL)是指一系列非关系型数据库系统,它们不依赖于固定模式的数据存储方式,能够灵活处理大规模、高并发的数据需求。键值对存储适用于简单的数据结构;文档存储支持复杂的数据对象;列式存储优化了大数据量的读写性能;而图数据库则擅长处理复杂的关系网络。每种类型的NoSQL数据库都有其独特的优势和应用场景,本文将详细分析它们的特点及应用实例。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
  • 深入解析Hadoop的核心组件与工作原理
    本文详细介绍了Hadoop的三大核心组件:分布式文件系统HDFS、资源管理器YARN和分布式计算框架MapReduce。通过分析这些组件的工作机制,帮助读者更好地理解Hadoop的架构及其在大数据处理中的应用。 ... [详细]
  • 近期参与了一个旨在提高在线平台大规模查询响应速度的项目,预计处理的数据量为2-3亿条,数据库并发量约为每秒1500次,未来可能增至3000次。通过对比Redis和MongoDB,最终选择了MongoDB,因其具备优秀的横向扩展性和GridFS支持下的Map/Reduce功能。 ... [详细]
author-avatar
主播新鲜看连
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有