mongoengine - 如何在嵌入文档内部的键上创建索引?
MongoDB 允许在嵌套文档中的某个键上创建索引:
db.things.ensureIndex({"address.city": 1})
有没有办法使用 mongoengine 来实现这个功能?
2 个回答
7
class Nested(EmbeddedDocument):
a = StringField(unique=True)
b = StringField()
class Outer(Document):
inner = EmbeddedDocumentField(Nested)
c = StringField()
meta = {"indexes": ['inner.a']}
就这些。
2
你可以在嵌入文档中指定一个字段,并设置为 unique=True
,这样可以确保这个字段的值是唯一的,不会重复。
>>> class Nested(EmbeddedDocument):
... a = StringField(unique=True)
... b = StringField()
...
>>> class Outer(Document):
... inner = EmbeddedDocumentField(Nested)
... c = StringField()
...
>>> o = Outer()
>>> o.c = 'abc'
>>> o.inner = Nested(a='a', b='b')
>>> o.save()
>>> o2 = Outer()
>>> o2.c = 'abc'
>>> o2.inner = Nested(a='a', b='B')
>>> o2.save()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "mongoengine/document.py", line 176, in save
raise OperationError(message % unicode(err))
mongoengine.queryset.OperationError: Tried to save duplicate unique keys (E11000 duplicate key error index: test.outer.$inner.a_1 dup key: { : "a" })