mongoengine - 如何在嵌入文档内部的键上创建索引?

4 投票
2 回答
2997 浏览
提问于 2025-04-16 23:18

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" })

撰写回答