一. 在python脚本中, 我们通常可以使用pymongo模块实现与mongodb数据库的交互, 但是在使用Django框架进行定制开发的web server 项目中, 仍然使用pymongo模块的话, 显然是过于“原始”,这时可以考虑使用 mongoengine 模块, 通过这个模块, 可以封装数据模型, 然后以orm的形式进行crud,实现对mongodb数据库的操作。 这里仅对如何快速的使用这个模块做一个简单说明。
二. 安装 mongoengine
pip install mongoengine
三. django 配置文件中配置连接mongodb数据库
import mongoengine
# 创建与mongodb数据库的连接
MONGO_CONN = mongoengine.connect(
db="lowman", # 需要进行操作的数据库名称
alias='default', # 必须定义一个default数据库
host="192.168.3.69",
port=27017,
username="渣男不但丑",
password="28269",
authentication_source="admin", # 进行身份认证的数据库,通常这个数据库为admin“
)
四. models.py 中定义数据模型
import mongoengine
import datetime
from mongoengine import Document
class Book(Document): # 默认的会在 mongodb 中的 lowman 数据库创建一个名称为book的collection
"""
这里定义的模型, 实际上与使用关系型数据库时定义的模型,其定义的方式是一样的
只不过使用不同的模块,并继承自不同的父类, 数据保存在不同类型的数据库里。不需要执行迁移操作
"""
author = mongoengine.StringField(required=True, max_length=125)
email = mongoengine.StringField(required=True)
addr = mongoengine.StringField(required=True, max_length=125)
time = mongoengine.DateTimeField(default=datetime.datetime.now)
五. views.py 视图中进行crud操作
from .models import Book
book_obj = Book.objects.create(author="渣男不但丑, 屌丝也很忙", email="lowman@9527.com", addr="流浪地球村")
制作好模型以后, 就可以通过这个模型调用orm进行数据的增删改查,使用方式大体上与django自带的orm是相似的,这里就不对这种搬砖头的事情加以细述了,如果希望了解更加详细的使用方式及注意事项,可以查看官方文档: http://docs.mongoengine.org/
六、Objectid转为字符串
book_obj = Book.objects.filter(email=“lowman@9527.com”).first()
print(book_obj.id)
七、字符串转objectID
from bson.objectid import ObjectId
book_obj = Book.objects.filter(id=ObjectId(book_obj.id)).first()
根据_id查询数据代码如下
from bson.objectid import ObjectId
articles.find_one({‘_id’:ObjectId(‘50f0d76347f4ec148890ef1e’)})