蒙古引擎唯一的约束



我有这个模型:

class SourceModel(Document):
    name = StringField(
        primary_key=True,
        max_length=50,
        required=True,
    )
    # some fields

当我尝试运行这段代码时:

for source in SOURCES:
    SourceModel(**source).save()

我有这个错误:

mongoengine.errors.NotUniqueError: Tried to save duplicate unique keys (E11000 duplicate key error index: mirad.source_model.$name_1  dup key: { : null })

我不知道为什么会发生这个错误,因为我的模型中没有unique字段。我将此代码更改为:

for source in SOURCES:
    try:
        SourceModel(**source).save()
    except NotUniqueError:
         old_source = SourceModel.objects(name=source['name']).first()
         print old_source  # this line print None
为什么

您可能没有在文档模型中定义唯一索引。但是在某个时间点,为"name"创建了一个唯一的索引。

你需要在mongodb中删除索引,你可以在shell中这样做:

 db = new Mongo().getDB("mirad");
 db.source_model.dropIndex("name_1")

最新更新