MongoDB和MongoEngine¶
使用MongoDB之类的文档数据库是关系SQL数据库的常见替代方法。此模式显示如何使用 MongoEngine 一个文档映射器库,用于与MongoDB集成。
正在运行的MongoDB服务器和 Flask-MongoEngine 是必需的。::
pip install flask-mongoengine
配置¶
可以通过在``app.config``上定义``MONGODB_SETTINGS``并创建一个``MongoEngine``实例来完成基本设置。:
from flask import Flask
from flask_mongoengine import MongoEngine
app = Flask(__name__)
app.config['MONGODB_SETTINGS'] = {
"db": "myapp",
}
db = MongoEngine(app)
映射文档¶
要声明表示Mongo文档的模型,请创建一个继承自 Document
并声明每个字段。::
import mongoengine as me
class Movie(me.Document):
title = me.StringField(required=True)
year = me.IntField()
rated = me.StringField()
director = me.StringField()
actors = me.ListField()
如果文档有嵌套字段,请使用 EmbeddedDocument
定义嵌入文档的字段和 EmbeddedDocumentField
在父文档中声明。::
class Imdb(me.EmbeddedDocument):
imdb_id = me.StringField()
rating = me.DecimalField()
votes = me.IntField()
class Movie(me.Document):
...
imdb = me.EmbeddedDocumentField(Imdb)
创建数据¶
用字段的关键字参数实例化文档类。您还可以在实例化后为字段属性赋值。然后调用 doc.save()
. ::
bttf = Movie(title="Back To The Future", year=1985)
bttf.actors = [
"Michael J. Fox",
"Christopher Lloyd"
]
bttf.imdb = Imdb(imdb_id="tt0088763", rating=8.5)
bttf.save()
查询¶
使用课堂 objects
用于进行查询的属性。关键字参数在字段上查找相等的值。::
bttf = Movies.objects(title="Back To The Future").get_or_404()
查询运算符可以通过使用双下划线将其与字段名连接来使用。 objects
以及通过调用它返回的查询是不可重复的。::
some_theron_movie = Movie.objects(actors__in=["Charlize Theron"]).first()
for recents in Movie.objects(year__gte=2017):
print(recents.title)
文档¶
使用MongoEngine定义和查询文档的方法还有很多。有关详细信息,请查看 official documentation .
Flask-MongoEngine在mongoengine上添加了有用的实用程序。看看他们的 documentation 也。