MongoEngine:EmbeddedDocument v / s。ReferenceField
EmbeddedDocument
将允许将文档存储在另一个文档中,而RefereneField
仅存储其引用。但是,他们正在实现类似的目标。他们有特定的用例吗?
-
答案实际上取决于打算如何处理存储在mongodb中的数据。重要的是要记住,a
ReferenceField
将指向mongodb中另一个集合中的文档,而aEmbeddedDocument
被存储在同一集合中的同一文档中。考虑以下模式:
Person -> name -> address Address -> street -> city -> country
如果您希望每个人只有一个地址,并且每个地址仅与一个人相关联(一对一关系),并且通常要在数据库中查询一个或多个
Person
文档,则Person.address字段应是EmbeddedDocumentField
。如果您希望每个人都有一个以上的地址,但每个地址仅与一个人相关(一对多关系),而您仍然主要查询一个人,则可以使用
EmbeddedDocumentListField
。如果您希望每个人都有一个以上的地址,并且每个地址将与许多人相关联(多对多关系),则可能应该使用
ReferenceField
。但是,即使您是一对一或一对多的,如果
Address
您感兴趣的是数据模型的一部分,那么将其存储在自己的集合中可能也会有好处,因为它使聚合和建立索引更加容易。需要考虑的另一点是,除非您将其关闭,否则mongoengine将
ReferenceField
在检索文档时取消对每个文档的引用-
这可能会引入大量ReferenceField
或引用非常大的文档而导致性能下降。