保存新的 Django 模型对象给出重复键

Saving new django model object gives duplicate key

Python3.7 上的 Django 2.2.3,带有 Amazon RDS Postgres 数据库。

保存新对象不适用于此公司模型:

class Company(models.Model):
    name = models.CharField(max_length=255, unique=True)
comp = Company(name='test')
comp.save()

给予

UniqueViolation: duplicate key value violates unique constraint "appname_company_pkey"
DETAIL:  Key (id)=(29) already exists

我可以确认是的,table 中有一个 id=29 的条目。

为什么 Django 试图使用它作为 ID,我该如何阻止它?

我解决了。

Django Import/Export app 不会在导入后重置任何序列。这意味着在导入数据的任何表中的任何添加都将失败。

解决方法如下:

python manage.py sqlsequencereset <your app name> | python manage.py dbshell

这会像这样生成并运行 SQL:

SELECT setval(pg_get_serial_sequence('"appname_company"','id'), coalesce(max("id"), 1), max("id") IS NOT null) FROM "appname_company";