保存新的 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";
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";