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